目录
一、MySQL安装、连接、修改密码操作
二、库的操作
2.1 创建数据库
2.2 字符集和校验规则
2.3 操控数据库
2.4 修改数据库
2.5 删除数据库
2.6 数据库的备份和恢复
2.7 查看连接情况
前情提要:
我的服务器操作系统是Ubuntu20.04,安装的是MySQL8.0版本。
一、MySQL安装、连接、修改密码操作
参考了这篇博客:【究极详细版】Ubuntu安装配置MySQL_ubuntu配置mysql-CSDN博客
二、库的操作
MySQL编写SQL语句时默认是不区分大小写的。(表名、列名、别名等标识符是否区分大小写取决于服务器操作系统的文件系统以及MySQL的配置设置,Linux系统是区分大小写的)
2.1 创建数据库
语法:
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,
create_specification] ...]create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
说明:
- 大写的表示关键字
- [ ] 是可选项,使用可选项时不用加上方括号
- create_specification:是在创建数据库时可以指定的额外选项或规范,用于定义数据库的字符集、校对规则等属性。
- CHARACTER SET: 指定数据库采用的字符集
- COLLATE: 指定数据库字符集的校验规则(编码集)
例如:
CREATE DATABASE mytest
CHARACTER SET utf8mb4
COLLATE utf8mb4_unicode_ci;
说明:创建一个名为mytest的数据库,并指定字符集为utf8mb4(这是MySQL 5.5.3及以上版本推荐使用的字符集,因为它支持存储任何Unicode字符,包括表情符号)以及默认的校对规则utf8mb4_unicode_ci。这些选项确保了新创建的数据库使用utf8mb4字符集和相应的utf8mb4_unicode_ci校对规则。
补充:
- 在MySQL中创建库,本质是在Linux下建立目录,一个目录对应一个库。
- 但不是仅仅创建一个库,还会包含存储数据库的相关文件。
- 所以要删除数据库或者添加数据库时,不要对底层的目录进行修改,而是在MySQL中使用SQL语句完成。
2.2 字符集和校验规则
字符集:字符集定义了数据库中可以存储的字符集以及每个字符的编码方式。
数据库编码集:是字符集的具体实现,用于确保数据以正确的格式存储在数据库中。
以下是一些常见的字符集:
- latin1:西欧语言,ISO 8859-1字符集。
- utf8:Unicode字符集,最多支持每个字符3字节。
- utf8mb4:扩展的Unicode字符集,最多支持每个字符4字节,可以存储任何Unicode字符,包括emoji。
校验规则:定义了字符集中字符的比较规则,包括字符的排序顺序和比较时的区分度(例如是否区分大小写、重音等)。(字符集通常与校验规则搭配使用。因为同一个字符集可以有不同的校验规则。)
查看系统默认字符集以及校验规则:
show variables like 'character_set_database';
show variables like 'collation_database';
查看数据库支持的字符集:
show charset;
查看数据库支持的字符集校验规则:
show collation;
校验规则对数据库的影响:
1. 不区分大小写:
- 当校验规则不区分大小写时,例如utf8_general_ci,查询和排序时不会区分字母的大小写。
- 即使表中存在大小写不同的同义词,查询也会将它们视为相同的值。
- 例如,查询SELECT * FROM users WHERE username = 'John'会匹配到john、JOHN和John等所有大小写形式。
2. 区分大小写:
- 当校验规则区分大小写时,例如utf8_bin,查询和排序时会严格区分字母的大小写。
- 表中的同义词必须完全匹配查询条件的大小写格式。
- 例如,查询SELECT * FROM users WHERE username = 'John'只会匹配到John,而不会匹配到john或JOHN。
3. 进行查询:
- 校验规则会影响查询的性能,因为不区分大小写的校验规则在比较时可能会进行额外的转换,从而影响查询速度。
- 区分大小写的校验规则在比较时更快,因为它们直接比较字符的二进制表示。
4. 结果排序:
- 校验规则决定了排序的顺序,包括字母、数字和特殊字符的顺序。
- 例如,utf8_unicode_ci校验规则会根据Unicode标准来排序字符,这可能与常规的ASCII排序不同。
- 区分大小写的校验规则在排序时会根据大小写规则来排列字符,而不会将大小写视为相同。
2.3 操控数据库
查看数据库
show databases;
显示创建语句
show create database 数据库名;
说明:
- MySQL 建议我们关键字使用大写,但是不是必须的。
- 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
- /*!40100 default.... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话
- \G 是一个转义序列,用于指定输出格式。使用\G时,MySQL会将查询结果以垂直格式输出,而不是默认的水平格式。这种格式使得查询结果更容易阅读,尤其是在结果比较长时。而且会去掉一些不必要的字符。
2.4 修改数据库
语法:
ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name
说明:
- 对数据库的修改主要指的是修改数据库的字符集,校验规则
例如: 将 mytest 数据库字符集改成 gbk :alter database mytest charset=gbk;
2.5 删除数据库
DROP DATABASE [IF EXISTS] db_ name;
执行删除之后的结果:
- 数据库内部看不到对应的数据库
- 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删
注意:不要随意删除数据库,这是因为MySQL的删除操作是物理删除,一旦删除,数据将无法恢复。因此比较建议删除前考虑创建一个数据库的备份,以防止错误删除。
2.6 数据库的备份和恢复
备份(在bash中执行):
语法:
mysqldump -P3306 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径
示例:将mytest库备份到文件(退出连接)
mysqldump -P3306 -u root -p123456 -B mytest > /MySQL/mytest.sql
这时,可以打开看看 mytest.sql 文件里的内容,其实把我们整个创建数据库,建表,导入数据的语句都装载这个文件中。
- 上面的命令都是退出MySQL,在Linux命令行中输入的。
- 路径中的MySQL是自定义创建的文件夹,用来保存备份文件。
- mysqldump:这是一个MySQL客户端工具,用于将数据库的结构和数据导出为SQL语句。
- -P3306:指定MySQL服务器的端口号。MySQL的默认端口号是3306,但有时服务器管理员会更改它。
- -u root:指定MySQL服务器的用户名。root是MySQL的超级用户,拥有最高权限。
- -p 密码:指定MySQL服务器的密码。密码需要用单引号括起来,如果密码中包含空格或特殊字符,需要用单引号括起来。
- -B mytest:指定要备份的数据库名。mytest是您想要备份的数据库的名称。
- > /MySQL/mytest.sql:将导出的SQL语句输出到文件。/MySQL/mytest.sql是你指定保存备份文件的路径和文件名。
如果备份的不是整个数据库,而是其中的一张表:
mysqldump -u root -p 数据库名 表名1 表名2 > 数据库所要存储的文件路径
同时备份多个数据库mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库备份存储的文件路径
如果备份一个数据库时,没有带上-B参数, 在恢复数据库时,需要先创建空数据库,然后使用数据库,再使用source来还原。
还原(在MySQL中执行):
source 备份库所在的完整路径;
2.7 查看连接情况
语法:
show processlist;
可以告诉我们当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登陆的,很有可能你 的数据库被人入侵了。以后大家发现自己数据库比较慢时,可以用这个指令来查看数据库连接情况。