MySQL库的操作(二)

创建数据库create

语法:

c 复制代码
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,create_specification] ...]

create_specification:
	[DEFAULT] CHARACTER SET charset_name
	[DEFAULT] COLLATE collation_name

说明:

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

  • COLLATE: 指定数据库字符集的校验规则

例子
创建数据库 db_name------本质:在/var/lib/mysql创建一个目录

c 复制代码
create database db_name;

删除数据库 db_name------本质:删除那个目录

c 复制代码
drop database db_name;

创建前进行校验,是否已经创建数据库
create database if not exists db_name;

字符集与校验规则

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

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

一句话来说:数据通过字符集进行存储,通过校验规则进行查找。

例子 :两个数据库,用同一个字符集进行存储,用不同的校验规则进行读取。 两个数据库各建两张表,这两张表中都存储name(char)类型的A与a,然后进行查询(读取)。

  • 校验规则使用utf8_ general_ ci(不区分大小写),仅查询a时,A,a都被查询。
  • 校验规则使用utf8_ bin(区分大小写),仅查询a时,只有A或者a被查询。

甚至当多个字母(含大小写)插入表中时,进行排序,结果也是不一样的(校验规则会影响比较)

数据库无论对数据做任何操作,都必须保证操作和编码必须是编码一致的(数据的产生、传输、存储、读取" 全链路使用统一(或可兼容映射)的字符编码规则)。

字符集(Character Set)和校验规则(Collation)本质上是强关联、一一对应的核心关系------ 字符集定义 "能存储哪些字符",校验规则则定义 "这些字符该如何比较 / 排序",一套字符集必然对应一套或多套专属的校验规则,反之一个校验规则也只属于某一个字符集。

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

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

注意:当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8,校验规则是:utf8_ general_ c

查看数据库支持的字符集show charset;

结果如下
查看数据库支持的字符集校验规则show collation

给数据库设置编码(这里是创建时设置)

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

c 复制代码
create database db_name charset=utf8;
create database db_name character set utf8;//两种写法

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

c 复制代码
create database db_name charset=utf8 collate utf8_general_ci;

操纵数据库

查看数据库show

c 复制代码
show databases;
c 复制代码
show tables

数据库删除drop

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

结果:数据库文件夹被删除,里面的数据表全部被删,所以不要随便删除数据库。

修改数据库alter

语法:

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

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

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

c 复制代码
alter database mytest charset=gbk;

备份和恢复

备份

语法:

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

例:将helloworld库备份到文件(注:需要退出mysql,Bash命令)

这时,可以打开看看 mytest.sql 文件里的内容,其实把我们整个创建数据库,建表,导入数据的语句都装载这个文件中。

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

c 复制代码
mysqldump -u root -p密码 数据库名 表名1 表名2 > 数据库存放路径

同时备份多个数据库

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

还原

需要在连接mysql后进行还原

c 复制代码
mysql> source 数据库文件所在的路径(xxx.sql所在路径);

本质上就是在执行一次所有的语句。

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

相关推荐
todoitbo2 小时前
多模数据库技术解析:以KingbaseES MongoDB兼容版为例
数据库·mongodb·kingbasees·金仓数据库
正在走向自律2 小时前
ksycopg2实战:Python连接KingbaseES数据库的完整指南
数据库·python·国产数据库·kingbase·kingbasees·数据库平替用金仓·ksycopg2
廋到被风吹走2 小时前
【数据库】【MongoDB】全栈深度指南:文档模型到分布式集群
数据库·分布式·mongodb
·云扬·3 小时前
MySQL各版本核心特性演进与主流分支深度解析
数据库·sql·mysql
砚边数影3 小时前
AI开发依赖引入:DL4J / Java-ML 框架 Maven 坐标配置
java·数据库·人工智能·深度学习·机器学习·ai·maven
砚边数影3 小时前
AI环境搭建(一):JDK17 + Maven 配置,Java开发环境标准化流程
数据库·人工智能·ai·ai编程
檀越剑指大厂3 小时前
金仓数据库以“多模融合”引领文档数据库国产化新篇章
数据库
煎蛋学姐3 小时前
SSM星河书城9p6tr(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·用户管理·ssm 框架·星河书城·线上书城
jason成都4 小时前
实战 | 国产数据库 R2DBC-JDBC 桥接踩坑记 - JetLinks适配达梦数据库
java·数据库·物联网