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有多少个用户在登陆

相关推荐
一枚正在学习的小白3 分钟前
PG数据文件位置迁移
linux·运维·服务器·数据库
真的想不出名儿19 分钟前
上传头像到腾讯云对象存储-前端基于antdv
java·数据库·腾讯云
Dreams_l30 分钟前
初识redis(分布式系统, redis的特性, 基本命令)
数据库·redis·缓存
数据库知识分享者小北31 分钟前
Qoder + ADB Supabase :5分钟GET超火AI手办生图APP
数据库·后端
hjbf42 分钟前
理解并解决 MySQL 中的 "You can't specify target table for update in FROM clause" 错误
mysql
一路向北_Coding1 小时前
MyBatis Generator让你优雅的写SQL
mysql·mybatis
点亮一颗LED(从入门到放弃)1 小时前
SQLite3数据库——Linux应用
linux·数据库·sqlite
济南java开发,求内推2 小时前
mongodb一个服务器部署多个节点
服务器·数据库·mongodb
武子康2 小时前
Java-148 深入浅出 MongoDB 聚合操作:$match、$group、$project、$sort 全面解析 Pipeline 实例详解与性能优化
java·数据库·sql·mongodb·性能优化·系统架构·nosql
程序猿(雷霆之王)2 小时前
MySQL——复合查询
数据库·mysql