• 首页
  • 国产小呦泬泬99精品
  • 最近2019中文字幕在线高清
  • 免费看少妇作爱视频
  • 曰批全过程免费视频在线观看网站
  • 国色天香在线观看全集免费播放
  • 婆岳同床双飞呻吟
  • 最近2019中文字幕在线高清你的位置:三级小说 > 最近2019中文字幕在线高清 > 学习 MySQL 的 28 个小技能

    学习 MySQL 的 28 个小技能

    发布日期:2022-06-18 17:11    点击次数:89

    学习 MySQL 的 28 个小技能

    序论

    无论是运维、开垦、测试,照旧架构师,数据库技巧都是一个 必备加薪神器,那么,一直说学习数据库、学 MySQL,到底是要学习它的哪些东西呢?

    一、若何快速摆布 MySQL? 1.培养兴味

    兴味是最佳的老师,无论学习什么常识,兴味都不错极地面普及学习成果。不管学习 MySQL5.7 照旧 MySQL8.0 都不例外!

    2.夯实 SQL 基础

    缱绻机范围的技巧相配强调基础,刚运行学习可能还刚毅不到这小数。跟着技巧应用的深 入,只消有着塌实的基础功底,才能在技巧的路途上走得更快、更远。对于 MySQL 的学习来说, SQL 语句 是其中最为基础的部分,好多操作都是通过 SQL 语句来收尾的。是以在学习的经由中, 读者要多编写 SQL 语句,对于团结个功能,使用不同的收尾语句来完成,从而深切透露其不同之处。

    🏆 这里不错参考著作:基础篇:数据库 SQL 初学教程

    3.实时学习新常识

    正确、灵验地利用搜索引擎,不错搜索到好多对于 MySQL 的掂量常识。同期,参考别 人贬假造题的思绪,也不错吸取他人的训导,实时获取最新的技巧府上。

    4.多实践操作

    数据库系统具有极强的操作性,需要多脱手上机操作。在推行操作的经由中才能发现问题, 并思考贬假造题的门径和思绪,只消这么才能普及实战的操作才调。

    二、技能共享

    底下共享学习 MySQL 的 28 个不得不露出的小技能!

    1、MySQL 中若何使用颠倒字符?

    诸如单引号 ',双引号 ",反斜线 \ 等标志,这些标志在 MySQL 中不行径直输入使用,否则会产贸易想之外的完毕。

    例如:

    假定 Lucifer 表中需要存入一排记载,值为 lucifer's dog,其中的单引号 ' 号,若是不做转义,则无法告捷奉行:

    mysql> create table lucifer (id int,name char(100)); Query OK, 0 rows affected (0.02 sec)  mysql> insert into lucifer values (1,'lucifer's dog');     '>      '> mysql>   ^C mysql> 

    在 MySQL 中,这些颠倒字符称为转义字符,在输入时需要以反斜线标志 \ 起原,是以在使用单引号和双引号时应分别输入 \' 卤莽 \",输入反斜线时应该输入 \\,其他颠倒字符还有回车符 \r,换行符 \n,制表符 \tab,退格符 \b 等。

    mysql> create table lucifer (id int,name char(100)); Query OK, 0 rows affected (0.03 sec)  mysql> insert into lucifer values (1,'lucifer\'s dog'); Query OK, 1 row affected (0.00 sec)  mysql> select * from lucifer; +------+---------------+ | id   | name          | +------+---------------+ |    1 | lucifer's dog | +------+---------------+ 1 row in set (0.00 sec) mysql>  

    📢 正式: 在向数据库中插入这些颠倒字符时,一定要进行转义处理。

    2、MySQL 中不错存储文献吗?

    谜底天然是不错的!

    MySQL 中的 BLOB 和 TEXT 字段类型不错存储数据量较大的文献,不错使用这些数据类型 存储图像、声息卤莽是大容量的文本内容,例如网页卤莽文档。

    mysql> create table view(id int unsigned NOT NULL AUTO_INCREMENT, catid int,title varchar(256),picture MEDIUMBLOB, content TEXT,PRIMARY KEY (id)); Query OK, 0 rows affected (0.03 sec)  mysql> show fields from view; +---------+--------------+------+-----+---------+----------------+ | Field   | Type         | Null | Key | Default | Extra          | +---------+--------------+------+-----+---------+----------------+ | id      | int unsigned | NO   | PRI | NULL    | auto_increment | | catid   | int          | YES  |     | NULL    |                | | title   | varchar(256) | YES  |     | NULL    |                | | picture | mediumblob   | YES  |     | NULL    |                | | content | text         | YES  |     | NULL    |                | +---------+--------------+------+-----+---------+----------------+ 5 rows in set (0.00 sec)  mysql>  

    天然使用 BLOB 卤莽 TEXT 可 以存储大容量的数据,然而对这些字段的处迎接缩小数据库的性能。

    📢 正式: 若是并非必要,不错选拔只储存文献的旅途。

    3、MySQL 中若何奉行永别大小写的字符串相比?

    MySQL 是 不永别大小写 的,因此字符串相比函数也不永别大小写。

    mysql> select 'TRUE' from dual where 'DOG' = 'dog'; +------+ | TRUE | +------+ | TRUE | +------+ 1 row in set (0.00 sec) 

    若是想奉行永别大小写的相比,不错在字符串前边添加 BINARY 关节字。

    mysql> select 'TRUE' from dual where BINARY'DOG' = 'dog'; Empty set (0.00 sec)  mysql>  

    例如默许情况下,’DOG‘=’dog‘ 复返完毕为 TRUE,若是使用 BINARY 关节字,BINARY’DOG’=‘dog’ 完毕为 FALSE,在永别大小写的情况下,’DOG’ 与 ’dog’ 并不交流。

    4、若何从日历时辰值中获取年、月、日等部分日历或时辰值?

    MySQL 中,日历时辰值以字符串格局存储在数据表中,因此不错使用字符串函数分别截取日历时辰值的不同部分。

    mysql> create table lucifer(date date); Query OK, 0 rows affected (0.04 sec)  mysql> show fields from lucifer; +-------+------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+------+------+-----+---------+-------+ | date  | date | YES  |     | NULL    |       | +-------+------+------+-----+---------+-------+ 1 row in set (0.00 sec)  mysql> insert into lucifer values (now()); Query OK, 1 row affected, 1 warning (0.00 sec)  mysql> select * from lucifer; +------------+ | date       | +------------+ | 2021-11-25 | +------------+ 1 row in set (0.00 sec) 

    例如某个称呼为 date 的字段有值 2021-11-25,若是只需要得到年值,不错输入 LEFT(date, 4),这么就得到了字符串左边运行长度为 4 的子字符串,即 YEAR 部分的值;

    mysql> select LEFT(date, 4) from lucifer; +---------------+ | LEFT(date, 4) | +---------------+ | 2021          | +---------------+ 1 row in set (0.00 sec) 

    若是要获取月份值,不错输入 MID(date,6,2),字符串第 6 个字符运行,长度为 2 的子字符串恰好为 date 中的月份值。同理,读者不错字据其他日历和时辰的位置,缱绻并获取相应的值。

    mysql> select MID(date,6,2) from lucifer; +---------------+ | MID(date,6,2) | +---------------+ | 11            | +---------------+ 1 row in set (0.00 sec) 
    5、若何调动默许的字符集?

    CONVERT() 函数调动指定字符串的默许字符集!

    MySQL 的装配和确立经由中,其中的一个设施是不错选拔 MySQL 的默许字符集。然而,若是只调动字符集,莫得必要把确立经由从头奉行一遍,在这里,一个浅易的方式是 修改确立文献。

    读者不错在修改字符集时使用 SHOW VARIABLES LIKE 'character_set_%'; 卤莽 status 敕令张望刻下字符集,以进行对比。

    mysql> SHOW VARIABLES LIKE 'character_set_%'; +--------------------------+----------------------------+ | Variable_name            | Value                      | +--------------------------+----------------------------+ | character_set_client     | latin1                     | | character_set_connection | latin1                     | | character_set_database   | utf8mb3                    | | character_set_filesystem | binary                     | | character_set_results    | latin1                     | | character_set_server     | utf8mb4                    | | character_set_system     | utf8mb3                    | | character_sets_dir       | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.00 sec)  mysql> status -------------- mysql  Ver 8.0.26-0ubuntu0.21.04.3 for Linux on aarch64 ((Ubuntu))  Connection id:          10 Current database: Current user:           root@localhost SSL:                    Not in use Current pager:          stdout Using outfile:          '' Using delimiter:        ; Server version:         8.0.26-0ubuntu0.21.04.3 (Ubuntu) Protocol version:       10 Connection:             Localhost via UNIX socket Server characterset:    utf8mb4 Db     characterset:    utf8mb4 Client characterset:    latin1 Conn.  characterset:    latin1 UNIX socket:            /var/run/mysqld/mysqld.sock Binary data as:         Hexadecimal Uptime:                 36 min 55 sec  Threads: 2  Questions: 325  Slow queries: 0  Opens: 181  Flush tables: 3  Open tables: 69  Queries per second avg: 0.146 --------------  mysql>  

    MySQL 确立文献称呼为 my.cnf,该文献在 MySQL 的装配目次底下。修改确立文献中的 default-character-set 和 character-set-server 参数值, 97视频将其改为想要的字符集称呼,如 gbk、gb2312、latinl 等,修改完之后从头启动 MySQL 做事,即可收效。

    ## 找到 my.cnf 位置 root@modb:~# find /etc -iname my.cnf -print /etc/alternatives/my.cnf /etc/mysql/my.cnf  ## 修改字符集 在[client ]底下加入 default-character-set=utf8 在[ mysqld ] 底下加 character_set_server=utf8  ## 重启 mysql 收效 service mysql restart 

    此时,登录 MySQL 后使用 SHOW VARIABLES LIKE 'character_set_%'; 卤莽 status 敕令张望修改完毕!

    6、DISTINCT 不错应用于系数的列吗?

    查询完毕中,若是需要对列进行降序排序,不错使用 DESC,这个关节字只能对其前边的列 进行降序摆设。

    mysql> select * from lucifer; +------+----------+ | id   | name     | +------+----------+ |    1 | lucifer  | |    2 | lucifer1 | |    3 | lucifer2 | +------+----------+ 3 rows in set (0.00 sec)  mysql> select * from lucifer order by id desc; +------+----------+ | id   | name     | +------+----------+ |    3 | lucifer2 | |    2 | lucifer1 | |    1 | lucifer  | +------+----------+ 3 rows in set (0.00 sec) 

    例如,要对多列都进行降序排序,必须要在每一列的列名后头加 DESC 关节字。

    mysql> select * from lucifer order by id desc,name desc; +------+----------+ | id   | name     | +------+----------+ |    3 | lucifer2 | |    2 | lucifer1 | |    1 | lucifer  | +------+----------+ 3 rows in set (0.00 sec) 

    而 DISTINCT 不同,DISTINCT 不行部分使用。换句话说,DISTINCT 关节字应用于系数列而不仅是它后头的第一个指定列。

    例如,查询 2 个字段 sex,age,若是不同记载的这 2 个字段的组合值都不同,则系数记载都会被查询出来。

    mysql> select * from lucifer; +------+-----------+--------+------+ | id   | name      | sex    | age  | +------+-----------+--------+------+ |    1 | xiaoli    | male   |   20 | |    1 | xiaoliu   | female |   21 | |    1 | xiaozhang | female |   21 | |    1 | xiaowu    | female |   21 | +------+-----------+--------+------+ 4 rows in set (0.00 sec)  mysql> select distinct sex,age from lucifer; +--------+------+ | sex    | age  | +--------+------+ | male   |   20 | | female |   21 | +--------+------+ 2 rows in set (0.00 sec)  mysql>  
    7、ORDER BY 不错和 LIMIT 夹杂使用吗?

    在使用 ORDER BY 子句时,应保证其位于 FROM 子句之后,若是使用 LIMIT,则必须位于 ORDER BY 之后,若是子句法例不正确,MySQL 将产生不实讯息。

    ✅ 正确用法:

    mysql> select * from lucifer order by age desc limit 2,4; +------+--------+--------+------+ | id   | name   | sex    | age  | +------+--------+--------+------+ |    1 | xiaowu | female |   21 | |    1 | xiaoli | male   |   20 | +------+--------+--------+------+ 2 rows in set (0.00 sec) 

    ❎ 不实用法:

    mysql> select * from lucifer limit 2,4 order by age desc; ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'order by age desc' at line 1 mysql>  
    8、什么时候使用引号?

    在查询的时候,会看到在 WHERE 子句中使用条目,有的值加上了单引号,而有的值未加。

    mysql> select * from lucifer where sex = 'female'; +------+-----------+--------+------+ | id   | name      | sex    | age  | +------+-----------+--------+------+ |    1 | xiaoliu   | female |   21 | |    1 | xiaozhang | female |   21 | |    1 | xiaowu    | female |   21 | +------+-----------+--------+------+ 3 rows in set (0.00 sec)  mysql>  

    单引号用来截止字符串,若是将值与字符串类型列进行相比,则需要截止引号;而用来与数值进行相比则不需要用引号。

    mysql> select * from lucifer where age = 20; +------+--------+------+------+ | id   | name   | sex  | age  | +------+--------+------+------+ |    1 | xiaoli | male |   20 | +------+--------+------+------+ 1 row in set (0.00 sec)  mysql>  
    9、在 WHERE子句中 AND 和 OR 必须使用圆括号吗?

    任何时候使用具有 AND 和 OR 操作符的 WHERE 子句,都应该使用圆括号明确操作法例。

    mysql> select * from lucifer where (age = 20 or sex = 'female') and name != 'xiaowu'; +------+-----------+--------+------+ | id   | name      | sex    | age  | +------+-----------+--------+------+ |    1 | xiaoli    | male   |   20 | |    1 | xiaoliu   | female |   21 | |    1 | xiaozhang | female |   21 | +------+-----------+--------+------+ mysql> 3 rows in set (0.00 sec) 

    若是条目较多,即使能详情缱绻次第,默许的缱绻次第也可能会使 SQL 语句不易透露,因此使 用括号明确操作符的次第,是一个好的习尚。

    10、更新卤莽删除表时必须指定 WHERE子 句吗?

    个人提议系数的 UPDATE 和 DELETE 语句完全在 WHERE 子句中指定条目。

    mysql> update lucifer set age = 22 where name = 'xiaoliu'; Query OK, 1 row affected (0.01 sec) Rows matched: 1  Changed: 1  Warnings: 0  mysql> select * from lucifer where name = 'xiaoliu'; +------+---------+--------+------+ | id   | name    | sex    | age  | +------+---------+--------+------+ |    1 | xiaoliu | female |   22 | +------+---------+--------+------+ 1 row in set (0.00 sec)  mysql>  

    若是不详 WHERE 子句,则 UPDATE 或 DELETE 将被应用到表中系数的行。

    mysql> update lucifer set age = 22; Query OK, 3 rows affected (0.01 sec) Rows matched: 4  Changed: 3  Warnings: 0  mysql> select * from lucifer; +------+-----------+--------+------+ | id   | name      | sex    | age  | +------+-----------+--------+------+ |    1 | xiaoli    | male   |   22 | |    1 | xiaoliu   | female |   22 | |    1 | xiaozhang | female |   22 | |    1 | xiaowu    | female |   22 | +------+-----------+--------+------+ 4 rows in set (0.00 sec)  mysql>  

    因此,除非照实缱绻更新卤莽删除系数记载,否则要正式使用不带 WHERE 子句的 UPDATE 或 DELETE 语句。

    📢 正式: 提议在对表进行更新和删除操作之前,使用 SELECT 语句证明需要删除的记载,以免形成无法挽回的完毕。

    11、索引对数据库性能如斯迫切,应该若何使用它?

    索引的优点:

    通过创建唯一索引不错保证数据库表中每一排数据的唯一性。 不错给系数的 MySQL 列类型成立索引。 不错大大加速数据的查询速率,这是使用索引最主要的原因。 在收余数据的参考完美性方面不错加速表与表之间的连系。 在使用分组和排序子句进行数据查询时也不错权贵减少查询平分组和排序的时辰

    舛错:

    创建和选藏索引组要破钞时辰,而且跟着数据量的增多所破钞的时辰也会增多。 索引需要占磁盘空间,除了数据表占数据空间除外,每一个索引还要占一定的物理空间。若是有大批的索引,索引文献可能比数据文献更快达到最大文献尺寸。 当对表中的数据进行增多、删除和修改的时候,最近2019中文字幕在线高清索引也要动态选藏,这么就缩小了数据的选藏速率。

    使用索引时,需要概括沟通索引的优点和舛错。

    为数据库选拔正确的索引是一项复杂的任务。若是索引列较少,则需要的磁盘空间和选藏支拨 都较少。若是在一个大表上创建了多种组合索引,索引文献也会延长很快。

    而另一方面,索引较多 可袒护更多的查询。可能需要锻练多少不同的想象,才能找到最灵验的索引。不错添加、修改和删 除索引而不影响数据库架构或应用圭臬想象。

    因此,应尝试多个不同的索引从而建设最优的索引。

    12、尽量使用短索引(前缀索引)

    对字符串类型的字段进行索引,若是可能应该指定一个前缀长度。

    例如,若是有一个 CHAR(255) 的列,若是在前 10 个或 30 个字符内,多数值是唯独的,则不需要对通盘列进行索引。

    mysql> select * from lucifer; +------+-----------+--------+------+ | id   | name      | sex    | age  | +------+-----------+--------+------+ |    1 | xiaoli    | male   |   22 | |    1 | xiaoliu   | female |   22 | |    1 | xiaozhang | female |   22 | |    1 | xiaowu    | female |   22 | +------+-----------+--------+------+ 4 rows in set (0.00 sec)  mysql> create index idx_lucifer_name on lucifer (name(4)); Query OK, 0 rows affected (0.03 sec) Records: 0  Duplicates: 0  Warnings: 0  mysql> show index from lucifer; +---------+------------+------------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+---------+------------+ | Table   | Non_unique | Key_name         | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment | Visible | Expression | +---------+------------+------------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+---------+------------+ | lucifer |          1 | idx_lucifer_name |            1 | name        | A         |           1 |        4 |   NULL | YES  | BTREE      |         |               | YES     | NULL       | +---------+------------+------------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+---------+------------+ 1 row in set (0.01 sec)  mysql>  

    短索引不仅不错普及查询速率而且不错勤俭磁盘空间、减少 I/O 操作。

    13、MySQL 存储经由和函数有什么区别?

    在实质上它们都是存储圭臬。

    函数:

    只能通过 return 语句复返单个值卤莽表对象; 限定相比多,不行用临时表,只能用表变量,还有一些函数都不可用等等; 不错镶嵌在 SQL 语句中使用,不错在 SELECT 语句中行为查询语句的一个部分调用;

    存储经由:

    不允许奉行 return,然而不错通过 out 参数复返多个值; 限定相对就相比少; 一般是行为一个独处的部分来奉行; 14、存储经由中的内容不错调动吗?

    不不错!

    当今,MySQL 还不提供对已存在的存储经由代码的修改,若是必须要修改存储经由,必须使用 DROP 语句删除之后,再从头编写代码,卤莽创建一个新的存储经由。

    不得不说,这方面照旧 Oracle 做的相比好。

    15、存储经由中不错调用其他存储经由吗?

    不错!

    存储经由包含用户界说的 SQL 语句麇集,不错使用 CALL 语句调用存储经由,天然在存储经由中也不错使用 CALL 语句调用其他存储经由,然而不行使用 DROP 语句删除其他存储经由。

    16、存储经由的参数不要与数据表中的字段名交流。

    在界说存储经由参数列表时,应正式把参数名与数据库表中的字段名区别开来,否则将出 现无法预期的完毕。

    17、存储经由的参数不错使用华文吗?

    一般情况下,可能会出现有储经由中传入华文参数的情况,例如某个存储经由字据用户的 名字查找该用户的信息,传入的参数值可能是华文。这时需要在界说存储经由的时候,在后头加 上 character set gbk,否则调用存储经由使用华文参数会出错,比如界说 userInfo 存储经由,代码 如下:

    CREATE PROCEDURE useInfo(IN u_name VARCHAR(50) character set gbk, OUT u_age INT)

    18、MySQL 中视图和表的区别以及掂量是什么?

    两者的区别:

    视图是照旧编译好的 SQL 语句,是基于 SQL 语句的完毕集的可视化的表,而表不是; 视图莫得推行的物理记载,而基本表有; 表是内容,视图是窗口; 表占用物理空间而视图不占用物理空间,视图仅仅逻辑观念的存在,表不错实时对它进行修改,但视图只能用创建的语句来修改; 视图是张望数据表的一种门径,不错查询数据表中某些字段组成的数据,仅仅一些SQL 语句的麇集。从安全的角度来说,视图不错退避用户战争数据表,因而用户不露出表结构; 表属于全局模式中的表,是实表;视图属于局部模式的表,是虚表; 视图的建设和删除只影响视图本人,不影响对应的基本表;

    两者的掂量:

    视图(view)是在基本表之上建设的表,它的结构(即所界说的列)和内容(即系数记载) 都来自基本表,它依据基本表存在而存在。

    一个视图不错对应一个基本表,也不错对应多个基本表。

    视图是基本表的抽象和在逻辑钦慕上建设的新相关。

    19、使用触发器时须非凡正式!

    在使用触发器的时候需要正式,对于交流的表,交流的事件只能创建一个触发器。

    mysql> create trigger lucifer_tri before insert on lucifer for each row set NEW.id=NEW.id+1; Query OK, 0 rows affected (0.01 sec)  mysql>  mysql>  mysql> select * from lucifer; +------+-----------+--------+------+ | id   | name      | sex    | age  | +------+-----------+--------+------+ |    1 | xiaoli    | male   |   22 | |    1 | xiaoliu   | female |   22 | |    1 | xiaozhang | female |   22 | |    1 | xiaowu    | female |   22 | |    1 | lucifer   | male   |   20 | |    1 | lucifer   | male   |   20 | +------+-----------+--------+------+ 6 rows in set (0.00 sec)  mysql> insert into lucifer values(1,'lucifer','male',20); Query OK, 1 row affected (0.00 sec)  mysql> select * from lucifer; +------+-----------+--------+------+ | id   | name      | sex    | age  | +------+-----------+--------+------+ |    1 | xiaoli    | male   |   22 | |    1 | xiaoliu   | female |   22 | |    1 | xiaozhang | female |   22 | |    1 | xiaowu    | female |   22 | |    1 | lucifer   | male   |   20 | |    1 | lucifer   | male   |   20 | |    2 | lucifer   | male   |   20 | +------+-----------+--------+------+ 7 rows in set (0.00 sec) 

    比如对表 lucifer 创建了一个 BEFORE INSERT 触发器,那么若是对表 lucifer 再次创建一个 BEFORE INSERT 触发器,MySQL 将会报错,此时,只能以在表 lucifer 上创建 AFTER INSERT 卤莽 BEFORE UPDATE 类型的触发器。

    mysql> create trigger lucifer_tri before insert on lucifer for each row set NEW.id=NEW.id+1; ERROR 1359 (HY000): Trigger already exists mysql>  

    活泼的利用触发器将为操作省去好多困难。

    20、实时删除不再需要的触发器触发器

    界说之后,每次奉行触发事件,都会激活触发器并奉行触发器中的语句。

    若是需求发生变化,而触发器莫得进行相应的调动卤莽删除,则触发器仍然会奉行旧的语句,从而会影响新的数据的完美性。

    mysql> drop trigger lucifer_tri; Query OK, 0 rows affected (0.03 sec)  mysql>  

    因此,要将不再使用的触发器实时删除。

    21、应该使用哪种门径创建用户?(3种方式)

    创建用户有 3 种门径:

    使用 CREATE USER 语句创建用户 在 mysql.user 表中添加用户 使用 GRANT 语句创建用户(仅限 MySQL 8 版块以下使用)

    一般情况, 最佳使用 GRANT 卤莽 CREATE USER 语句,而不要径直将用户信息插入 user 表,因为 user 表中存储了全局级别的权限以非凡他的账户信息,若是有时梗阻了 user 表中的记载,则可能会对 MySQL 做事器形成很大影响。

    -- 使用 CREATE USER 语句创建用户 mysql> create user 'lucifer'@'localhost' identified by 'lucifer'; Query OK, 0 rows affected (0.01 sec)  mysql>   -- 在 mysql.user 表中添加用户 mysql> select MD5('lucifer'); +----------------------------------+ | MD5('lucifer')                   | +----------------------------------+ | cae33a0264ead2ddfbc3ea113da66790 | +----------------------------------+ 1 row in set (0.00 sec)  mysql>  mysql> INSERT INTO mysql.user(Host, User, authentication_string, ssl_cipher, ssuex509_i09_sr, x5ubject) VALUES ('lohoscalt',uci 'lfer MD5('1',lucifer'), '', '',; '') Query OK, 1 row affected (0.01 sec)  mysql>   -- 使用 GRANT 语句创建用户 mysql> GRANT SELECT ON*.* TO 'lucifer2'@localhost IDENTIFIED BY 'lucifer'; ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IDENTIFIED BY 'lucifer'' at line 1 mysql> 

    📢 正式: 由于测试使用的是 MySQL 8 版块,照旧不撑持 GRANT 径直创建用户,5.7 版块依然是撑持的。

    22、mysqldump 备份的文献只能在 MySQL 中使用吗?

    逻辑备份器具,适用于系数的存储引擎,撑持温备、完全备份、部分备份、对于 InnoDB 存储引擎撑持热备。

    mysqldump 备份的文本文献推行是数据库的一个副本,使用该文献不仅不错在 MySQL 中规复数据库,而且通过对该文献的浅易修改,不错使用该文献在 SQL Server 卤莽 Sybase 等其他数据库中规复数据库。

    root@modb:~# mysqldump -uroot -p hr > /root/hr.db Enter password:  root@modb:~#  root@modb:~# ll hr.db  -rw-r--r-- 1 root root 25327 Nov 26 08:52 hr.db 

    这在某种进度上收尾了数据库之间的迁徙。

    23、若何选拔备份器具?

    字据备份的门径(是否需要数据库离线)不错将备份分为:

    热备(Hot Backup) 冷备(Cold Backup) 温备(Warm Backup)

    MySQL 中进行不同方式的备份还要沟通存储引擎是否撑持,如 MyISAM 不撑持热备,撑持温备和冷备。而 InnoDB 撑持热备、温备和冷备。

    一般情况下,咱们需要备份的数据分为以下几种:

    表数据 二进制日记、InnoDB 事务日记 代码(存储经由、存储函数、触发器、事件转机器) 做事器确立文献

    底下是几种常用的备份器具:

    mysqldump:逻辑备份器具,适用于系数的存储引擎,撑持温备、完全备份、部分备份、对于 InnoDB 存储引擎撑持热备。 cp、tar 等存档复制器具:物理备份器具,适用于系数的存储引擎、冷备、完全备份、部分备份。 lvm2 snapshot:借助文献系统经管器具进行备份。 mysqlhotcopy:名不副实的一个器具,仅撑持 MyISAM 存储引擎。 xtrabackup:一款由 percona 提供的相配雄伟的 InnoDB/XtraDB 热备器具,撑持完全备份、增量备份。

    径直复制数据文献是最为径直、快速的备份门径,但舛错是基本上不行收尾增量备份。备份时必须确保莫得使用这些表。若是在复制一个表的同期做事器正在修改它,则复制无效。备份 文献时,最佳关闭做事器,然后从头启动做事器。

    24、平淡应该掀开哪些日记?

    日记既会影响 MySQL 的性能,又会占用大批磁盘空间。因此,若是毋庸要,应尽可能少地 开启日记。

    字据不同的使用环境,不错沟通开启不同的日记。

    例如,在开垦环境中优化查询成果低的语句,不错开启慢查询日记;

    开启慢查询日记: 不错让MySQL记载下查询逾越指定时辰的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

    -- 查验是否开启慢查询 mysql> show variables like 'slow_query%'; +---------------------+------------------------------+ | Variable_name       | Value                        | +---------------------+------------------------------+ | slow_query_log      | OFF                          | | slow_query_log_file | /var/lib/mysql/modb-slow.log | +---------------------+------------------------------+ 2 rows in set (0.00 sec)  mysql> show variables like 'long_query_time'; +-----------------+-----------+ | Variable_name   | Value     | +-----------------+-----------+ | long_query_time | 10.000000 | +-----------------+-----------+ 1 row in set (0.01 sec)  -- 开启慢查询日记 mysql> set global slow_query_log='ON';  Query OK, 0 rows affected (0.00 sec)  -- 成立查询逾越10秒就记载 mysql> set global long_query_time=10; Query OK, 0 rows affected (0.00 sec)  -- 再次查验是否开启 mysql> show variables like 'slow_query%'; mysql> +---------------------+------------------------------+ | Variable_name       | Value                        | +---------------------+------------------------------+ | slow_query_log      | ON                           | | slow_query_log_file | /var/lib/mysql/modb-slow.log | +---------------------+------------------------------+ 2 rows in set (0.00 sec) 

    若是需要记载用户的系数查询操作,不错开启通用查询日记;

    mysql> show variables like 'general_log%'; +------------------+-------------------------+ | Variable_name    | Value                   | +------------------+-------------------------+ | general_log      | OFF                     | | general_log_file | /var/lib/mysql/modb.log | +------------------+-------------------------+ 2 rows in set (0.00 sec)  -- 开启通用查询日记 mysql> SET GLOBAL general_log=1;  Query OK, 0 rows affected (0.00 sec)  mysql> show variables like 'general_log%'; +------------------+-------------------------+ | Variable_name    | Value                   | +------------------+-------------------------+ | general_log      | ON                      | | general_log_file | /var/lib/mysql/modb.log | +------------------+-------------------------+ 2 rows in set (0.00 sec) 

    若是需要记载数据的变更,不错开启二进制日记;不实日记是默许开启的。

    mysql> show variables like 'log_bin%'; +---------------------------------+-----------------------------+ | Variable_name                   | Value                       | +---------------------------------+-----------------------------+ | log_bin                         | ON                          | | log_bin_basename                | /var/lib/mysql/binlog       | | log_bin_index                   | /var/lib/mysql/binlog.index | | log_bin_trust_function_creators | OFF                         | | log_bin_use_v1_row_events       | OFF                         | +---------------------------------+-----------------------------+ 5 rows in set (0.00 sec)  mysql>  
    25、若何使用二进制日记?

    二进制日记主要用来记载数据变更。

    若是需要记载数据库的变化,不错开启二进制日记。基于二进制日记的特质,不仅不错用来进行数据规复,还可用于数据复制。

    root@modb:/var/lib/mysql# ls binlog* binlog.000001  binlog.000002  binlog.index root@modb:/var/lib/mysql# mysqlbinlog binlog.000001 | mysql -u root -p                                             Enter password:  root@modb:/var/lib/mysql#  

    在数据库按时备份的 情况下,若是出现数据丢失,不错先用备份规复大部分数据,然后使用二进制日记规复最近备份后变更的数据。在双机热备情况下,不错使用 MySQL 的二进制日记记载数据的变更,然后将变更部分复制到备份做事器上。

    26、若何使用慢查询日记?

    慢查询日记主要用来记载查询时辰较长的日记。

    在开垦环境下,不错开启慢查询日记来记载查询时辰较长的查询语句,然后对这些语句进行优化。

    root@modb:/var/lib/mysql# cat /var/lib/mysql/modb-slow.log /usr/sbin/mysqld, Version: 8.0.26-0ubuntu0.21.04.3 ((Ubuntu)). started with: Tcp port: 3306  Unix socket: /var/run/mysqld/mysqld.sock Time                 Id Command    Argument root@modb:/var/lib/mysql#  

    通过配 long_query_time 的值,不错活泼地摆布不同进度的慢查询语句。

    27、是不是索引建设得越多越好?

    合理的索引不错普及查询的速率,但不是索引越多越好。

    在奉行插入语句的时候,MySQL 要为新插入的记载建设索引。是以过多的索引会导致插入操作变慢。原则上是只消查询用的字段才建设索引。

    使用索引时,需要概括沟通索引的优点和舛错。

    28、若何使用查询缓冲区?

    查询缓冲区不错普及查询的速率,然而这种方式只合乎查询语句相比多、更新语句相比少 的情况。

    默许情况下查询缓冲区的大小为 0,也即是不可用。不错修改 queiy_cache_size 以接济查询缓冲区大小;修改 query_cache_type 以接济查询缓冲区的类型。

    在 my.cnf 中修改 query_cache_size 和 query_cache_type 的值如下所示:

    [mysqld] query_cache_size= 512M  query_cache_type= 1 query_cache_type=1 

    默示开启查询缓冲区。

    只消在查询语句中包含 SQL_NO_CACHE 关节字时,才不会使用查询缓冲区。不错使用 FLUSH QUERY CACHE 语句来刷新缓冲区,算帐查询缓冲区中的碎屑。

     



    Powered by 三级小说 @2013-2022 RSS地图 HTML地图