第二阶段:mysql(学完就隐藏版)

news2024/11/27 14:34:26
  • 第一章:部署数据库系统(注意关闭防火墙,selinux安装)

    •   安装mysql配置的相关文件:yum install https://dev.mysql.com/get/mysql80-community-release-el7-5.noarch.rpm(centos9:yum install https://dev.mysql.com/get/mysql80-community-release-el9-1.noarch.rpm)
    • 安装mysql,建议关闭校验(yum install mysql-community-server)
    • 启动mysql(要先启动服务,才会有/var/log/mysqld.log,这个文件才有初始密码):systemctl start mysqld
    • 查看密码:grep password | /var/log/mysqld.log
    • 登录mysql:mysql -u 用户名 -p(exit退出mysql)
    • 运行 MySQL 安全设置:使用临时密码登录 MySQL(看看可不可以用),然后在shell中运行安全设置程序来配置 root 密码等安全选项:mysql_secure_installation(先完成密码重置)
    • 表数据一般,放在/var/lib/mysql中
    • 我想设置简单密码,但是必须要完成密码重置后才可以
      • 登录 MySQL查看密码策略设置:SHOW VARIABLES LIKE 'validate_password%';
      • 修改密码策略(可选):
        • 设置密码策略为 LOW:SET GLOBAL validate_password.policy = LOW;设置最小密码长度为 6:SET GLOBAL validate_password.length = 6;可以选择降低对特殊字符和数字的要求:SET GLOBAL validate_password.mixed_case_count = 0; SET GLOBAL validate_password.number_count = 0; SET GLOBAL validate_password.special_char_count = 0;更改密码:ALTER USER 'root'@'localhost' IDENTIFIED BY '简单密码';
  • 第二章:sql数据库操作语言ddl

    • sql语言分类

      • sql:结构化查询语言:用于存取数据,查询数据,更新数据,管理关系型数据库系统{sql语言由ibm开发}
      • 分类

        • DDL:数据定义语言:数据库,数据表,视图,索引,存储过程
        • DML:数据操纵语言:插入insert,删除delete,更新update
        • DQL:数据查询语言:查询select
        • DCL:数据控制语言:控制用户各类权限
    • 名词解释

      • 数据库服务器

        • 运行数据库的物理设备:硬件+系统+mysqlsever
      • 数据库(show databases;显示当前数据库管理系统的默认库)

        • 默认数据库(管理表的单元)
          • information_schema
            • 类型:虚拟库
            • 功能:该库存储了系统中的数据库对象信息。它不包含实际的数据,而是提供了对数据库结构(元数据)的查询接口。
            • 内容:表、列、权限、约束、触发器等的元数据。
            • 用途:通常用于查询数据库结构或对象的信息,例如查询所有表的列表、列的详细信息等。
          • mysql
            • 类型:系统库
            • 功能:存储 MySQL 数据库服务器的核心数据,包括用户权限、数据库、表的定义、权限管理、时间区信息等。
            • 内容:用户、授权、系统变量、存储过程等信息。
            • 用途:与安全性和访问控制密切相关,所有关于用户权限的更改都会影响 mysql 数据库中的表。
          • performance_schema
            • 类型:虚拟库
            • 功能:用于监控 MySQL 服务器的性能,提供低开销的方式来分析服务器的执行情况。
            • 内容:它包含与 MySQL 性能相关的各种事件、状态、等待锁定等信息。
            • 用途:用于调试和优化 MySQL 的性能,通过收集和显示性能数据来帮助分析查询、锁定、内存使用等。
          • sys
            • 类型:视图库
            • 功能:MySQL 5.7 开始引入的系统库,基于 performance_schemainformation_schema,为 DBA 提供了更为友好的性能分析视图。
            • 内容:简化了对性能数据的查询,提供了易于理解的视图和帮助调优的建议。
            • 用途:为数据库管理员提供有用的系统和性能监控信息的简单视图,常用于性能调优和问题排查。
        • 管理记录的单元
      • 记录(行)

        • 信息的载体,数据的管理单元
      • 字段(列)

        • 字段名,类型(长度),约束条件(可选)。数据的属性。
      • 类型

        • 对于不同的数据进行分类,比如“你好”是文本,12是数字,这两个类型就不一样了,或者图片和文本,音频和数字。为了方便区分,另外节省空间就有了类型。
      • 约束

        • 对字段的一些强行命令,比如姓名字段不可为空,就是说必须要有个名字。
      • 图示

        无关紧要图
        数据库结构图
    • ddl(命令不区分大小写,但是参数区分)

      • ddl-库

        • 定义数据库
          • 创建数据库

            • create database 数据库名;(分号不能忘)

          • 查看当前dbms(数据库管理系统)中的所有数据库:show databases;

        • 选择/进入数据库
          • use 数据库名;   选择并使用数据库

          • select database():查看当前位于的数据库

          • 查看创建过程:show create table/database 表名/数据库名

        • 删除数据库
          • drop database  数据库名;

        • 系统中的位置
          • /var/lib/mysql(使用yum安装的,mysql实际文件夹位置)

      • ddl-表

        • 目的
          • 表是数据库存放数据的基本单位,由若干个字段构成,用记录(行)存放数据。
        • 创建表
          • create table 表名 【这里有空格】(
            列名1 类型(【长度】) 【完整性约束】,
            列名1 类型(长度) 【完整性约束】,
            …………
            )【数据表的一些相关设置】;
        • 查看:当前数据库的所有表:show tables;对应表表结构:desc 表名;
      • 数据类型(mysql8.0)

        • 数值类型
          • 整型
            • int(有符号-214,783,648到214,783,647,无符号0到4,294,967,295)
            • tinyint(有符号-128到127,无符号0到255)
            • unsigned用法,在创建表的时候   类型   unsigned
            • zerofill 当不满足类型的最小宽度自动填充0,(同时会自动将列设置为 UNSIGNED),用法   类型(最小宽度)   zerofill。比如:int(最小宽度6) zerofill
          • 浮点型(小数收到长度约束四舍五入)
            • float(总位数《整数加小数位数》,小数点后位数):不写默认为float(10,3)双精度形式。{由于 FLOAT 是近似值存储,可能会出现精度损失。例如,在财务计算或精度要求较高的场合,不建议使用 FLOAT}
            • 精确小数decimal(总位数《整数加小数位数》,小数点后位数):不写默认decimal(7,0){精确存储,适合财务等精确场景}
        • 字符串类型
          • 字符型
            • char:定长字符串类型(默认1字符),适用于存储长度固定的字符串0-255字符{会删除末尾空格}
            • varchar:变长字符串类型(默认1字符),适合存储长度不一致的字符串65,535 字符(在行长度限制下){不会删除末尾空格}
          • 枚举与集合(选项为字符串类型)
            • 枚举enum(单选):只能选择一个预定义的字符串值(最多 65535 个不同的值)(以整数形式存储,映射到对应的字符串值)【enum('value1', 'value2', 'value3', ...)】
            • 集合set(多选):可以选择多个预定义的字符串值(最多 64 个不同的值)(以位图形式存储,多个值用位标识)【set('value1', 'value2', 'value3', ...)】{插入集合的时候insert into 表 values(‘枚举’,‘集合1,集合2……’)}
        • 时间日期类型(插入数据时用引号包起来)
          • 日期data(YYYY-MM-DD)
          • 时间time(HH:MM:SS)
          • 日期时间datatime(YYYY-MM-DD  HH:MM:SS)
          • 时区默认时间timestamp(自动管理插入和更新时间,使用这个类型,不添加值就默认当前时区时间)
          • 当前
            • curtime()当前时间,curdate()当前日期,now()当前日期时间
            • 可以通过select单独查看,也可以直接作为参数
      • 完整性约束

        • 默认值,是否空值:default,【not】null
          • create table ly (id int default 1 not null,name varchar(50) default ‘李叶’  not null);
        • 设置主键:primary key(数据在表中唯一,且不可以为空,主键唯一但是主键字段不唯一)
          • create table ly (id int default 1 primary key auto_increment);
        • 设置唯一性约束:unique(标志该字段值唯一不可以重复,可以为空<空可以重复>,一个表可以有多高unique)
          • create table ly ( id int ,name varchar(50) unique);
          • create table ly ( id int ,name varchar(50), unique(id,name));
        • 设置外键约束:foreign key(将多表联动起来,a表改变名字,对应b表也发生改变)(外键就像是硬链接,两个文件一个inode,而且作用只对对应字段值的行整体有用,比如删除主表一行,对应子表行删除,但是不能通过主表对子表行的某一项操作
          • 父表:create table ly (name varchar(50) not null,mail varchar(40),primary key(name));
          • 子表:create table ly1(student_name varcah(50),id int not null auto_increment,primary key(id),foreign key(name)reference ly(name)on update cascade on delete cascade);
          • 注意子表通过foreign key设置外键,通过reference声明与父表ly(name)关联(ly中的name是ly的主键才可以),on xxx表示在哪些权利上共享。
          • 注意
            • 外键引用的字段:外键必须引用另一个表中的主键唯一键(Primary Key 或 Unique Key)
            • 字段类型必须匹配:外键字段和被引用字段的数据类型必须兼容
            • 允许NULL值:外键字段可以允许为NULL,这意味着某条记录可以不引用父表中的任何记录。
            • 父表的记录必须存在:外键要求引用的父表中的主键记录必须已经存在
        • 设置复合主键约束:primary key
          • create table ly(id int,name char(10),sex char(2),primary key(id,name,【字段名】));
        • 设置字段自增:auto_increment(默认加1)
          • create table ly (id int auto_increment);
  • 第三章:sql数据库操作语言DML

    • 对数据的管理,写入,删除,更新。
    • 插入:insert into 表

      • insert into 表(表内字段)values (对应字段的值);
      • 不给定字段就表示表内所有字段:insert 表 values (按照顺序一次插入);
      • 多条数据插入:insert into 表(表内字段)values (对应字段的值),(对应字段的值);
      • 注意值的数据类型
    • 更新:update 表 set 

      • update 表 set 列名=值 where 条件;(按照条件行,修改对应列单元格值,如果没有条件就是整列)
    • 删除:delete from 表(删除行数据)

      • delete from 表 where 条件;(不加条件删整个表的数据)
  • 第四章:sql数据库查询语言DQL

    • 简单查询

      • select */列名(逗号隔开) from 表名;
      • select 列名*6 from 表名;(还可以四则运算查询)
    • 条件查询where

      • 单条件

        • select 查看的列 from 表 where 条件;
        • 可以使用=,<,>,>=,<=,!=/<>
      • 多条件and/or

        • select 查看的列 from 表 where 条件1 and/or 条件2……;and表示同时满足,or表示满足一项就可以了。
      • 关键字between and闭区间

        • select 查看的列名 from 表名 where 列名 between 开始 and 结束;在范围之中。
      • 关键字in集合查询。

        • select 查看列 from 表 where 条件列  in (匹配值,逗号分开);
      • 关键字is null/is not null,查询是否为空的值

        • select 查看列 from 表 where 条件列 is null;(注意空格也是字符,可以通过length(列),查看空格多少,中英文1个字符)
      • 关键字like模糊查询(%表示任意个(0到任意),_任意一个和shell脚本一样)

        • select 查看列 from 表 where 列 like “%”
    • 查询排序

      • select 查看列 from 表 order by 排序的列名(可以多列)asc(升序)/desc(降序)【limit 数字(表示排序到后的前几位,limit可以单独用但是要放到最后,比order还要后)】;(要知道,因为是排序,所以肯定是最后操作,所以排序放在其它操作最后)
    • 子查询

      • 将select语句的结果看做参数用(无论关键字是否有了()比如in,都建议在子查询外添加括号)包括,比如select * from (select * from 表 limit 30);这里将子查询的结果当做了表
    • 多表查询

  • 第五章:sql数据库控制语言DCL

    • DCL

      • 权限级别

        • global level:全局权限,所有表所有库

        • database level:数据库权限

        • table level:数据表权限

        • column level:表中某个字段的权限

      • mysql用户管理

        • 在 MySQL 数据库中,用户账户的信息存储在 mysql 数据库中的 user 表中。user 表中保存了所有 MySQL 用户的权限、认证方式、密码以及其他相关信息。(root下)

        • 创建用户:
          • create user '用户名'@'指定登录主机'   identified  by '密码';
            • 用户名:是你要创建的用户名。
            • 指定登录主机:表示允许该用户从哪个主机进行连接。常用的选项:
              • 'localhost':只允许从本地主机连接。
              • '%':允许从任何主机连接。
            • 密码:必要大小写数字符号且8位
        • 删除用户:
          • drop user '用户名'@'指定主机';
        • 修改用户密码:
          • select user();查看当前登录用户
          • 方法1:alter  user  '用户名'@'指定主机'  identified[译为验证]  by  '新密码';
          • 方法2:set  password  for   '用户名'@'指定主机'= '新密码';
          • 方法3:mysqladmin -u root -p'与-p没有空格'  password ‘新密码有空格’;
          • 丢失root密码怎么办?
            • vim  /etc/my.cnf添加skip-grant-tables(启动mysql时跳过授权密码)
            • 重启mysqld服务
            • 进入mysql -u root
            • update mysql.user set authentication_string='' where user='root';修改系统用户密码为空
            • vim /etc/my.cnf取消之前的skip-grant-tables
            • 进入系统修改root密码
              • 方法1:set password for '用户'@'localhost'='密码';
              • 方法2:alter user ‘用户名’@‘主机’ identified by ‘密码’;
        • 登录mysql:mysql -u username -p ‘密码’  【数据库名,直接进入数据库】
          • 如果需要从远程登录 MySQL,请确保 MySQL 服务器的配置允许外部连接,并使用对应的 host 参数:mysql -u username -p -h IP地址
          • -P:端口,mysql默认3306端口
          • -e  ‘sql命令’:免登录mysql直接执行数据库后面是命令
      • mysql权限原理

        • grant(给予)/revoke(撤销) 权限列表 on  数据库名.表名 to/from(取消用from)    '用户名'@'主机' [IDENTIFIED BY '密码'] [WITH GRANT OPTION];{使用*可以设置整个数据库或者这个dbms中的所有数据库}
        • revoke/grant 权限 (列名)   on  数据库名.表名   to/from(取消用from)  '用户名'@'主机';
          • 权限列表:指定要授予的权限,可以是以下任意一个或多个:

            • ALL PRIVILEGES(all也可以):授予所有权限。
            • SELECT:允许查询数据。
            • INSERT:允许插入数据。
            • UPDATE:允许更新数据。
            • DELETE:允许删除数据。
            • CREATE:允许创建新数据库和表。
            • DROP:允许删除数据库和表。
            • GRANT OPTION:允许将自己的权限授予其他用户。
          • ON 数据库名.表名:指定权限应用于哪个数据库和表。

            • 如果是对整个数据库授予权限,可以使用 数据库名.*
          • TO '用户名'@'主机':指定要授予权限的用户及其主机。

            • 用户名:要授予权限的用户名。
            • 主机:指定用户可以从哪个主机连接,常用的有 localhost(仅本地主机)和 %(任意主机,ip,%,网段+%都可以)。
          • [IDENTIFIED BY '密码']:可选项,通常在创建用户时使用,表示设置用户的密码。注意:在使用 GRANT 语句时,如果用户已经存在,则通常不需要这个选项。

          • [WITH GRANT OPTION]:可选项,通常用于授予 GRANT OPTION 权限,允许用户将他们所拥有的权限授予其他用户。

            • 转授的限制

              • 用户只能转授他们自己拥有的权限。例如,如果某用户只拥有 SELECT 权限,则他们不能授予其他用户 UPDATEDELETE 权限。
            • 安全风险

              • 授予 WITH GRANT OPTION 可能带来安全风险,因为它允许用户自行分配权限。因此,谨慎使用,确保只对可信任的用户启用该选项。
            • 撤销权限时的影响

              • 如果你撤销某用户的权限,并且该用户使用 WITH GRANT OPTION 授予了其他用户权限,系统将自动撤销该用户所转授的权限。
        • 刷新:flush privileges;查看:show   grants  for '用户名'@'主机'(show grants查看当前用户权限);

    • MySQL日志

      • 错误日志

        • 错误日志记录 MySQL 服务器的启动、停止以及在运行过程中发生的任何错误信息。它是管理员排查问题的关键日志文件,尤其是在 MySQL 启动失败或发生重大错误时。
        • 配置错误日志(重启生效):vim /etc/my.cnf    中  通过log_error=/var/log/mysql/error.log(默认)
        • 查看错误日志
          • cat 文件  或者     在mysql   中  select @@log_error;
      • 二进制日志

        • 二进制日志用于记录所有对数据库进行更改的事件,如 INSERTUPDATEDELETE 等。它不记录 SELECT 查询。二进制日志的主要作用是数据恢复和主从复制。
        • 配置二进制日志(重启生效):vim /etc/my.cnf    中  通过log_bin = /var/log/mysql/mysql-bin.log(默认)
        • 查看二进制日志
          • mysqlbinlog /var/log/mysql/mysql-bin.000001
      • 慢日志

        • 慢查询日志记录所有执行时间超过指定阈值(long_query_time)的查询语句。它是优化 MySQL 性能的重要工具,用于发现执行缓慢的查询。
  • 第六章:sql数据库备份管理

    • 备份技术

      • 冷备份

        • 冷备份是指在备份数据时,系统或数据库完全停止运行,并且不接受任何读写操作。整个系统处于“离线”状态,这种备份方式相对安全,因为没有用户活动或数据库事务在进行,数据的一致性得以保证。
        • 关闭数据库服务——tar数据库数据目录——cp/scp到备份文件存放位置
        • scp 本地文件路径 用户名@远程主机:远程路径
      • 热备份

        • 备份是指在系统或数据库正常运行不断服务的情况下进行的数据备份。它不需要停机,系统可以在备份过程中继续处理用户请求和事务。为了保证备份数据的一致性,通常会使用锁定机制或事务日志。
    • 备份模式

      • 完备备份

        • 完备备份是指将指定的所有数据、文件或数据库完整地备份,无论数据是否发生变化。这是最基础、最全面的一种备份方式。
      • 增量备份

        • 增量备份是指自上次备份(无论是完备备份还是增量备份)之后,仅备份发生了变化的数据。每次增量备份只包含自上次备份后新增或修改的数据。
      • 差异备份

        • 差异备份是指自上次完备备份之后,所有发生了变化的数据,不论中间是否有过增量备份或差异备份。每次差异备份的内容包括自上次完备备份以来所有的修改数据。
    • 备份操作

      • (percona-xtrabackup80,mysql8.0),(percona-xtrabackup24,mysql5.7)
      • 安装:

        • yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpmhttps://repo.percona.com/yum/percona-release-latest.noarch.rpm(无法使用就换版本比如:https://repo.percona.com/yum/percona-release-1.0-9.noarch.rpmhttps://repo.percona.com/yum/percona-release-1.0-9.noarch.rpmhttps://repo.percona.com/yum/percona-release-1.0-9.noarch.rpm)https://repo.percona.com/yum/percona-release-latest.noarch.rpm(仓库配置)yum makecache(刷新一下)
        • yum install percona-xtrabackup-80(安装软件)
      • 备份

        • # 1. 完整备份
          xtrabackup 【--defaults-file=配置文件位置,如果为/etc/my.cnf就可以不写】 --backup --target-dir=完整备份目录(要先创建) --user=mysql用户 --password=密码
          # --backup:指定进行备份操作
          # --target-dir:设置备份数据存放的目录
          # --user(简写-u用户名):用于连接 MySQL 的用户名
          # --password(简写-p密码):连接 MySQL 的密码
          
          # 2. 增量备份
          xtrabackup 【--defaults-file=配置文件位置,如果为/etc/my.cnf就可以不写】 --backup --target-dir=增量备份目录 --incremental --incremental-basedir=完全备份目录 --user=mysq用户  --password=密码
          # --incremental:启用增量备份
          # --incremental-basedir:指定上次完整备份的目录
          
          # 进行第二次增量备份
          xtrabackup 【--defaults-file=配置文件位置,如果为/etc/my.cnf就可以不写】 --backup --target-dir=增量备份目录2  --incremental --incremental-basedir=完全备份目录  --user=mysql目录  --password=密码
          
          # 3. 准备完整备份
          xtrabackup --prepare --target-dir=已经备份的完整备份目录
          # --prepare:准备备份,使其可用于恢复
          
          # 4. 准备增量备份
          xtrabackup --prepare --apply-log-only --target-dir=完全备份目录 --incremental-dir=某个增量备份
          # --apply-log-only:仅应用日志,但不标记为完全恢复(意思是告诉系统,我还有要加的,别急,最后一次增量不写,表示告诉系统可以了,我完整了,是一个完整备份,不要在来数据了,来了也不要。)
          
          # 5. 恢复备份(恢复要关mysqld)
          xtrabackup 【--defaults-file=配置文件位置,如果为/etc/my.cnf就可以不写】 --copy-back --target-dir=完全备份目录
          # --copy-back:将准备好的备份文件复制回 MySQL 数据目录
          
          # 6. 权限修复
          chown -R mysql:mysql /var/lib/mysql
          # 确保 MySQL 数据目录的权限正确
          
          # 7. 启动 MySQL 服务
          systemctl start mysqld
          
          # 排错:
          # 如果提示版本问题,就添加--no-server-version-check
          
          # 差异备份
          # 简单的说,就是基于完全备份+最后一次增量备份就可以了(注意不要有--apply-log-only)
          
          # 压缩与解压备份
          # --compess(放到备份/增量备份语句中xtrabackup --backup --compress --compress --target-dir=/压缩备份 --user=mysql_user --password=your_password)
          # --compress-threads=4:设置压缩时使用的线程数,默认为 1,设置为 4 代表用 4 个线程压缩。
          # --decmpress(xtrabackup --prepare --target-dir=/压缩目录)
          # 最后恢复就可以了,记得授权
  • 第七章:数据库代理服务与集群管理

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2204477.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端高频面试题2024/9/22(偏项目问题--通用后台管理系统)

文章目录 一.前端项目概述1.系统登录注册模块1.对注册的密码进行加密 &#xff08;使用加密中间件bcrypt.js&#xff09;2.登录成功后返回token3.前端登录页面有用到弹性布局&#xff0c;ref和reactive4.登录头像&#xff1a;文件上传 2.系统设置模块2.系统首页模块&#xff08…

Golang | Leetcode Golang题解之第472题连接词

题目&#xff1a; 题解&#xff1a; type trie struct {children [26]*trieisEnd bool }func (root *trie) insert(word string) {node : rootfor _, ch : range word {ch - aif node.children[ch] nil {node.children[ch] &trie{}}node node.children[ch]}node.isE…

ES-入门-http-多条件查询范围查询

must 表示多个条件需要同时满足 在postman 对应的参数配置如下 {"query": {"bool": {"must" : [{"match" :{"category":"小米"}},{"match":{"price":3999.00}}]}} } 如下图查询的结果是需…

JAVA科技赋能共享台球室无人系统小程序源码

科技赋能共享台球室无人系统 —— 智慧台球新体验 &#x1f3b1; 科技引领&#xff0c;台球室迎来无人新纪元 在这个日新月异的科技时代&#xff0c;共享经济的浪潮席卷而来&#xff0c;为我们的生活带来了诸多便利。而今天&#xff0c;我要为大家介绍的&#xff0c;正是科技…

便民医疗服务小程序后端springboot 服务 vue3 开发的后端 系统设计与实现

博主介绍&#xff1a;专注于Java&#xff08;springboot ssm springcloud等开发框架&#xff09; vue .net php phython node.js uniapp小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设&#xff0c;从业十五余年开发设计教学工作 ☆☆☆ 精彩专栏推荐订阅☆☆☆…

基于Springboot+Vue的智能推荐旅游平台 (含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统中…

初学Qt之环境安装与 hello word

环境&#xff1a; Qt Creator 4.11.0 (Community) Qt 5.14.0 目录 1.Qt环境配置 1.1 下载Qt 5.14.0 1.2 注册Qt账号 1.3 安装Qt 1.4 配置环境变量 2.创建项目 2.1 创建一个项目 2.2 初始代码解析 2.3 可视化GUI ​编辑 2.4 hello word 2.4.1 可视化hello word …

探索光耦:光耦助力高速电吹风安全与性能的革命性提升

在消费者对家电产品智能化与安全性需求日益增长的今天&#xff0c;高速电吹风作为个人护理领域的明星产品&#xff0c;正经历着前所未有的技术创新。其中&#xff0c;光耦&#xff08;光电耦合器&#xff09;的引入&#xff0c;无疑为电吹风的性能优化与安全保障开辟了新路径。…

Java基础(下)

泛型 Java 泛型&#xff08;Generics&#xff09; 是 JDK 5 中引入的一个新特性。使用泛型参数&#xff0c;可以增强代码的可读性以及稳定性。 编译器可以对泛型参数进行检测&#xff0c;并且通过泛型参数可以指定传入的对象类型 ArrayList<Person> persons new Arra…

【linux】冯诺依曼架构

&#x1f525;个人主页&#xff1a;Quitecoder &#x1f525;专栏&#xff1a;linux笔记仓 目录 01.冯诺依曼体系结构02.操作系统&#xff08;Operator System&#xff09;如何理解“管理”操作系统中实现“管理的先描述再组织” 03.系统调用与库函数系统调用库函数 01.冯诺依…

SSM(5)(动态sql <if>、<where>、返回主键值)

返回主键值&#xff1a; 方法一&#xff1a; useGeneratedKeys 为ture 声明 返回主键 keyProperty 表示要返回的值 封装到对象的属性中 但是这一种方法不支持Orcal数据库。 <insert id"save2" parameterType"com.findyou.entity.User" useGenerated…

[软件工程]—TFTP协议简要解析

TFTP协议简要解析 1.TFTP基本概念 TFTP&#xff08;Trivial File Transfer Protocol&#xff09;&#xff1a;是一个很小且易于实现的文件传送协议&#xff1a; TFTP使用客户服务器方式和使用UDP数据包&#xff0c;因此TFTP需要有自己的差错改正机制。TFTP只支持文件传输而不…

基于STM32 ARM+FPGA+AD的电能质量分析仪方案设计(一)硬件设计

电能质量分析系统硬件设计 3.1 电能质量分析系统设计要求 本系统实现对电能质量的高精度测量&#xff0c;根据国家相关电能质量分析仪器规定 标准以及对市场电能质量分析仪的分析&#xff0c;指定以下设计目标。 &#xff08; 1 &#xff09;电能质量参数测量精度&#xf…

基于 Prometheus+Grafana+Alertmanager 搭建 K8S 云监控告警平台(附配置告警至QQ、钉钉)

文章目录 一、机器规划二、部署安装 node-exporter、prometheus、Grafana、kube-state-metrics1、创建 monitor-sa 命名空间2、安装node-exporter组件2.1、说明2.2、应用资源清单2.3、通过node-exporter采集数据 3、k8s 集群中部署 prometheus3.1、创建一个 sa 账号3.2、将 sa …

智谱开放平台API调用解析

一、什么是智谱AI 智谱AI成立于2019年&#xff0c;由‌清华大学计算机系知识工程实验室的技术成果转化而来&#xff0c;是一家致力于人工智能技术研发和应用的公司。智谱致力于打造新一代认知智能大模型&#xff0c;专注于做大模型的中国创新。 二、智谱开放平台API调用 官方文…

遍历有向图链路(DFS算法)- 优化版

在上一节基础上&#xff0c;去除了节点的pre集合&#xff0c;只保留节点next的结合&#xff0c;对数据模型进行了优化&#xff0c;实现思想做了优化。 有向图示例&#xff1a; 基本思路 构建有向图数据模型校验有向图不能出现回路&#xff0c;即当前节点不能出现在历史链路中首…

Java控制台实现《多线程模拟龟兔赛跑》(实现Runnale接口,重写run()方法)

&#xff08;温馨提示&#xff1a;本题最重要的是学习思路&#xff0c;代码还有待优化和改进&#xff01;&#xff09; 下一篇博客进行优化。实现Callable接口&#xff1a;V call() throws Exception 。可以返回结果&#xff0c;以及可以抛出异常。&#xff08;启动线程比较麻烦…

spingboot项目打包到docker镜像[保姆级教程]

目录 1. 项目准备 2. 项目打包测试 3. docker配置 3.1 服务器端配置 3.2 开发IDEA配置 3.3 创建dockerfile 写在前面: 这博客一晃鸽了好久了,其实不是没有创作,只是懒得写博客了.日常都记录在自己的语雀小本本上了.好久没有出保姆级教程了&#xff0c;这次忽然想通过ide…

IP地址类型选择指南:动态IP、静态IP还是数据中心IP?

你是否曾经困惑于如何选择最适合业务需求的IP地址类型&#xff1f;面对动态IP、静态IP和数据中心IP这三种选择&#xff0c;你是否了解它们各自对你的跨境在线业务可能产生的深远影响&#xff1f; 在跨境电商领域&#xff0c;选择合适的IP类型对于业务的成功至关重要。动态IP、…

UART在Linux内核启动时突然不打印的问题

国庆前一天收到的任务&#xff0c;在一颗比较成熟的芯片的SDK基础上&#xff0c;移植一个新内核&#xff0c;让它能够在bitfile下跑在FPGA上。 看了芯片设计那边给的文档&#xff0c;对比过去的那颗&#xff0c;感觉也就改改寄存器&#xff0c;中断号&#xff0c;时钟&#xff…