MySQL库操作

目录

建库语句

字符集

操纵数据库

备份与恢复

查看连接情况


建库语句

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

我们可以对比着目录去理解一下建库语句

我们就会在数据库的存储目录建立这个**目录。**注意这个库本质就是个目录。

字符集

数据库编码集------存储数据时使用的字符集

数据库校验集------用来进行字段比较的字符集,读取数据时用的字符集。

一般这两个字符集是两个一一对应的东西。

查看系统默认字符集以及校验规则

sql 复制代码
show variables like 'character_set_database';  //默认编码集
show variables like 'collation_database';      //默认校验集

查看数据库支持的字符集校验规则

sql 复制代码
show charset;

这是我之前配置文件的编码集和字符集

我们默认的编码集和校验集,我们是可以在配置文件设置的。如果我们没有设置,就会继承我们root用户下的编码集和校验集。

这里举例一个校验集的栗子

上面是不区分大小写,下边是区分大小写。

sql 复制代码
create database test1 collate utf8_general_ci; //collate指定校验集
sql 复制代码
create database test1 collate utf8_bin; //collate指定校验集

utf8_general_ci结果(不区分大小写)

建个表

我们建立一个person表再传入一些元素

我们再来查一下a

我们是可以查到两个元素的。

utf8_bin结果(区分大小写)

省略上面步骤,直接出结果

只会出现a。

操纵数据库

查看数据库

sql 复制代码
show databases;

显示创建语句

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

可以查看建表时用的字符集

数据库删除

sql 复制代码
DROP DATABASE [IF EXISTS] db_ name;

修改数据库

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

比如我们要修改一个数据库的字符集

sql 复制代码
alter database test1 charset=gbk;

数据库备份

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

注意这个是在bash中执行的命令

这种打包文件要指定文件名字后缀为.sql

备份与恢复

恢复的时候我们是在sql客户端里面进行恢复的。

例如:

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

所谓恢复其实就是将之前的数据库的操作重新全部执行一遍。

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

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

同时备份多个数据库

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

注意:

查看连接情况

sql 复制代码
show processlist

可以告诉我们当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登陆的,很有可能你的数据库被人入侵了。以后大家发现自己数据库比较慢时,可以用这个指令来查看数据库连接情况。

相关推荐
听封5 分钟前
✨ 索引有哪些缺点以及具体有哪些索引类型
数据库·mysql
利瑞华10 分钟前
数据库索引:缺点与类型全解析
数据库·oracle
V+zmm1013413 分钟前
自驾游拼团小程序的设计与实现(ssm论文源码调试讲解)
java·数据库·微信小程序·小程序·毕业设计
ChinaRainbowSea25 分钟前
1. Linux下 MySQL 的详细安装与使用
linux·数据库·sql·mysql·adb
网络安全(华哥)1 小时前
网络安全服务实施流程管理 网络安全服务体系
运维·服务器·网络
致奋斗的我们1 小时前
Nginx反向代理及负载均衡
linux·运维·mysql·nginx·负载均衡·shell·openeluer
百锦再1 小时前
在Linux上创建一个Docker容器并在其中执行Python脚本
linux·python·docker
忧虑的乌龟蛋1 小时前
嵌入式 Linux:使用设备树驱动GPIO全流程
linux·服务器·嵌入式·imx6ull·gpio·点灯·pinctrl
朝九晚五ฺ2 小时前
【Linux探索学习】第三十弹——线程互斥与同步(上):深入理解线程保证安全的机制
linux·运维·学习
jay丿2 小时前
Redis 中列表(List)常见命令详解
数据库·redis·list