MySQL中对数据库的操作

文章目录

查看数据库列表

SQL 复制代码
show databases;

增删数据库

创建数据库

sql 复制代码
create database XXX;
create database if not exists XXX; // 不存在则创建,存在则报错
create database XXX charset=XXX; // 创建使用XXX字符集的数据库,不指明则根据配置文件默认
create database XXX charset=XXX collate XXX; // 创建XXX字符集并带校验规则的数据库

本质是在mysql中创建一个目录

删除数据库

sql 复制代码
drop database XXX;
drop database if exists XXX; // 存在则删除,不存在报错

本质是删除mysql中的一个目录

不能随意删除数据库,删完该库中的所有数据都没有了

认识系统编码

创建数据库的时候,有两个编码集:

  1. 数据库编码集 --- 数据库存储数据的编码
  2. 数据库校验集 --- 支持数据库进行字段比较使用的编码,本质是一种读取数据库中的数据采用的编码格式

数据库无论对数据做任何操作,都必须保证操作的编码是一致的

sql 复制代码
show variables like 'character_set_database'; // 查看系统默认字符集
show variables like 'collation_database'; // 查看系统默认校验规则
show charset; // 查看数据库支持的所有字符集
show collation; // 查看数据库支持的所有的校验规则

校验规则对数据库的影响

拿两个规则来进行比较:

utf8_general_ci //不区分大小写

utf8_bin // 区分大小写

首先创建一个规则为:utf8_general_ci 的数据库,在数据库里创建表并插入一些数据,接着指定查询某个数据看看会有什么情况。因为配置文件默认的规则为 utf8_general_ci 因此不需要指明创建

sql 复制代码
create database d1;

use d1; // 进入d1数据库

create table letter(name varchar(20)); // 创建一个名为letter的表,表中的字段只有name

insert into letter values('a'); // 往表中插入数据
insert into letter values('A');
insert into letter values('b');

select * from letter; // 查看表中数据
select * from letter where name='a'; // 在表中查询name字段为a的数据

可以看到单独查询a的话,A也会跟着出来,这就是不区分大小写的规则所产生的效果

下面再来看看区分大小写规则的效果,由于配置文件默认规则为 utf8_general_ci ,因此要指明 utf8_bin 才可以

sql 复制代码
create database d2 charset=utf8 collate utf8_bin; // 创建校验规则为utf8_bin的数据库

use b2; // 进入b2数据库

create table letter(name varchar(20)); // 创建表

insert into letter values('a'); // 往表中插入数据
insert into letter values('A');
insert into letter values('b');

select * from letter; // 查看表中数据
select * from letter where name='a'; // 在表中查询name字段为a的数据

可以看到这种规则下,只会出现a的数据。

综上可以看出,不同的校验规则有着不同的效果,根据需求选择规则去创建数据库即可

其他库的操作

查看当前所在数据库

sql 复制代码
select database();

修改数据库

主要是修改编码和校验规则

sql 复制代码
alter database XXX charset=XXX collate XXX;

查看数据库创建的细节

sql 复制代码
show create database XXX;

可以看到数据库的编码

备份和恢复

shell 复制代码
mysqldump -P端口号 -u用户名 -p密码 -B 数据库名 > 备份的路径
//注意是在系统中执行的指令

备份的本质就是将数据库的所有历史操作和数据全部重定向到系统中的文件

sql 复制代码
source 备份文件的路径;
//在mysql中执行

恢复的本质就是将备份在系统中的文件中锁存储的所有数据库操作在mysql中执行一遍

可以看到在系统中就存在了一个文件,该文件就存储着d1这个数据库的所有操作和数据。

那么恢复的话,直接在mysql中执行命令即可

执行了文件中记录的所有操作后,d1这个数据库就会被创建好。

注意事项

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

shell 复制代码
mysqldump -P端口号 -u用户名 -p 数据库名 表名1 表名2 > 路径 

同时备份多个数据库

shell 复制代码
mysqldump -P端口号 -u用户名 -p 数据库名1 数据库名2 > 路径

如果备份数据库不带-B选项,那么在恢复数据库时就要先创建空的数据库,然后使用数据库再恢复。

-B选项本质就是在备份文件中加入创建数据库的指令

查看连接情况

sql 复制代码
show processlist;

这个指令可以查看当前mysql有多少个用户在登陆

相关推荐
hef2883 小时前
如何生成特定SQL的AWR报告_@awrsqrpt.sql深度剖析单条语句性能
jvm·数据库·python
xcjbqd04 小时前
Python API怎么加Token认证_JWT生成与验证拦截器实现
jvm·数据库·python
二月十六4 小时前
SQL Server 2022 新语法:IS [NOT] DISTINCT FROM 彻底解决 NULL 比较难题
数据库·sqlserver
~ rainbow~4 小时前
前端转型全栈(四)——常见的错误及解决方案
数据库·oracle·全栈
数厘4 小时前
2.1SQL 学习:先懂数据库概念再学 SQL
数据库·sql·学习
Cat_Rocky5 小时前
redis哨兵模式
数据库·redis
广师大-Wzx5 小时前
一篇文章看懂MySQL数据库(下)
java·开发语言·数据结构·数据库·windows·python·mysql
hef2886 小时前
golang如何使用range over func_golang range over func迭代器使用方法
jvm·数据库·python
qq_380619167 小时前
html如何查看windows
jvm·数据库·python
爱学习的小邓同学7 小时前
MySQL --- MySQL数据库基础
数据库·mysql