【MySQL】库的操作

文章目录

💻创建数据库:

语法:

bash 复制代码
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,
create_specification] ...]
create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

  • 大写的表示关键字
  • \[\] 是可选项
  • CHARACTER SET: 指定数据库采用的字符集
  • COLLATE: 指定数据库字符集的校验规则

🖥️创建数据库案例:

bash 复制代码
create database db1;

创建一个使用utf8字符集的 db2 数据库:

bash 复制代码
create database db2 charset=utf8;

创建一个使用utf字符集,并带校对规则的 db3 数据库:

bash 复制代码
create database db3 charset=utf8 collate utf8_general_ci;

⌨️ 字符集和校验规则:

🖱️ 1.查看系统默认字符集以及校验规则

bash 复制代码
show variables like 'character_set_database';
show variables like 'collation_database';

📱2.查看数据库支持的字符集:

bash 复制代码
show charset;

📟3.查看数据库支持的字符集校验规则:

bash 复制代码
show collation;

🔧 4.校验规则对数据库的影响:

创建一个数据库,校验规则使用utf8_ general_ ci不区分大小写

bash 复制代码
create database test1 collate utf8_general_ci;
bash 复制代码
use test1;
bash 复制代码
create table person(name varchar(20));
bash 复制代码
insert into person values('a');
insert into person values('A');
insert into person values('b');
insert into person values('B');

查询结果:

创建一个数据库,校验规则使用utf8_ bin区分大小写

bash 复制代码
create database test2 collate utf8_bin;
bash 复制代码
use test2;
bash 复制代码
create table person(namevarchar(20));
bash 复制代码
insert into person values('a');
insert into person values('A');
insert into person values('b');
insert into person values('B');


🛠️ 查看数据库:

bash 复制代码
show databases;

⚙️显示创建语句:

bash 复制代码
show create database 数据库名;

说明:

  • MySQL 建议我们关键字使用大写,但是不是必须的。
  • 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
  • /*!40100 default... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话

修改数据库:

bash 复制代码
ALTER DATABASE db_name
[alter_spacification [,alter_spacification]...]
alter_spacification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

对数据库的修改主要指的是修改数据库的字符集,校验规则

实例: 将 mytest 数据库字符集改成 gbk

🧰备份和恢复:

📦1.备份:

bash 复制代码
mysqldump -P3306 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径

示例:将mytest库备份到文件(退出连接)

bash 复制代码
# mysqldump -P3306 -u root -p123456 -B mytest > D:/mytest.sql

🔗2.还原:

bash 复制代码
mysql> source D:/mysql-5.7.22/mytest.sql;

如果备份的不是整个数据库,而是其中的一张表,怎么做?

bash 复制代码
 mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql

同时备份多个数据库:

bash 复制代码
mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径

如果备份一个数据库时,没有带上-B参数, 在恢复数据库时,需要先创建空数据库,然后使用数据库,再使用source来还原。

📄查看连接情况:

bash 复制代码
show processlist;
相关推荐
phltxy11 小时前
MCP 从协议到 Spring AI 实战
人工智能·spring·oracle
睡不醒男孩03082311 小时前
第一篇:多云与多模态时代的企业级数据库云管理平台(DBaaS)选型指南
数据库·clup·中启乘数
小二·12 小时前
向量数据库实战
数据库
炘爚12 小时前
Phase 5:MySQL 连接池
数据库·mysql
潮起鲸落入海12 小时前
mysql主从复制读写分离
mysql
宁小法12 小时前
mysql - SQLSTATE[23000]报错类型
mysql·23000·报错类型
j_xxx404_12 小时前
MySQL库操作硬核解析:字符集、校验规则、大小写比较、备份恢复与连接排查
运维·服务器·数据库·人工智能·mysql·ai·oracle
minji...13 小时前
MySQL数据库 (五) MySQL表的约束(上),非空约束,默认值约束,零填充约束,主键约束,符合主键
数据库·mysql·表的约束·主键约束·非空约束·复合主键·零填充约束
拾贰_C13 小时前
【python | installation 】python 安装 | Windows | 命令使用
linux·数据库·ubuntu
贺今宵13 小时前
Vue 3 + Capacitor 使用jeep-sqlite,web端使用本地sqlite数据库
前端·数据库·vue.js·sqlite·web