【MySQL】库的操作

文章目录

💻创建数据库:

语法:

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

说明:

  • 大写的表示关键字
  • \] 是可选项

  • 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;
相关推荐
2401_884454151 小时前
如何管理只读表空间的备份_跳过只读表空间的RMAN优化策略
jvm·数据库·python
Languorous.1 小时前
MySQL CRUD实操详解:插入、查询、修改、删除,附可直接运行示例
数据库·mysql
woxihuan1234561 小时前
CSS移动端实现响应式导航菜单_利用媒体查询切换显示隐藏状态
jvm·数据库·python
CCPC不拿奖不改名1 小时前
PostgreSQL数据库部署linux服务器流程
linux·服务器·数据库·windows·python·docker·postgresql
彳亍1011 小时前
mysql如何通过mysqldump备份视图与触发器_使用相关参数
jvm·数据库·python
重生之小比特1 小时前
【MySQL 数据库】用户管理与权限控制
android·数据库·mysql
ZC跨境爬虫1 小时前
跟着 MDN 学 HTML day_60:(表单与按钮技能测试实战)
服务器·前端·javascript·数据库·ui·html
秦歌6661 小时前
Agent Skills详解
服务器·前端·数据库
Mahir081 小时前
Redis 分布式锁与 Redisson 深度解析:从原生实现到工业级解决方案
数据库·redis·分布式·缓存·面试