MYSQL库的操作

目录

创建数据库

字符集和校验规则

操作数据库


创建数据库

语法:

复制代码
CREATE DATABASE [IF NOT EXISTS] db_name [[DEFAULT] CHARSET=charset_name] [[DEFAULT] COLLATE=collation_name];
  • CHARSET:指定数据库所采用的编码格式。
  • COLLATE:指定数据库所采用的校验规则。

案例:

采用默认的编码格式和校验规则创建名为 db1 的数据库

复制代码
CREATE database db1;

注:默认的编码格式是utf8,默认的校验规则是utf8_general_ci。

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

复制代码
create database db2 charset=utf8;

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

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

字符集和校验规则

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

复制代码
show charset

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

复制代码
show collation;

查看数据库默认的字符集校验规则

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

校验规则与字符集对数据库的影响

校验规则会数据比较和排序的结果。如**utf8_general_ci 不区分大小写** ,utf8_bin 区分大小写。在进行**ORDER BY** 语句排序、WHERE 条件筛选、**DISTINCTGROUP BYHAVING**语句查询时,校验规则都会起作用。

操作数据库

查看数据库

我们可以使用 show databases 查看所有数据库:

显示创建语句

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

我们可以看到显示出的创建语句与我们创建时的不同,实际上在服务端MYSQL会对我们的SQL进行优化。

  • MySQL 建议我们关键字使用大写,但是不是必须的。
  • 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
  • /*!40100 default.... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话

修改数据库

复制代码
ALTER DATABASE db_name [[DEFAULT] CHARSET=character_name] [[DEFAULT] COLLATE=collation_name];

对数据库的修改主要是修改数据库的字符集或校验规则。

示例:将 db1 数据库字符集改成 gbk

删除数据库

复制代码
DROP DATABASE [IF EXISTS] db_name;

删除数据库后,该数据库下的所有表也都会被级联删除。

数据库的备份与恢复

备份:

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

还原:

复制代码
source 数据库备份存储的文件路径;

这里的备份实际上是将关于该库的创建数据库,建表,导入数据的语句都装载文件中,恢复实际上就是再执行一次所有语句。

表的备份与恢复

备份:

复制代码
mysqldump -u root -p 数据库名 表名1 表名2 > 文件路径

恢复:

复制代码
source 表备份存储的文件路径
相关推荐
Elastic 中国社区官方博客9 小时前
Elasticsearch:使用 Agent Builder 的 A2A 实现 - 开发者的圣诞颂歌
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
2301_816660219 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
qq_3721542310 小时前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
_下雨天.10 小时前
NoSQL之Redis配置与优化
数据库·redis·nosql
LiAo_1996_Y10 小时前
CSS如何实现文字渐变效果_通过background-clip实现艺术字
jvm·数据库·python
2401_8877245010 小时前
CSS如何让表单在手机端友好展示_利用Flexbox实现堆叠排版
jvm·数据库·python
数据库小组10 小时前
MySQL 删库后怎么恢复?binlog2sql 之外,NineData 还能做什么
数据库·sql·mysql·安全·数据·ninedata·删库
zhangchaoxies11 小时前
Layui轮播图(carousel)怎么设置自动播放间隔
jvm·数据库·python
切糕师学AI11 小时前
HBase:一文搞懂分布式宽列数据库(原理 + 架构 + 实战)
数据库·分布式·nosql·hbase·分布式宽列数据库·wide column db
competes11 小时前
慈善基金投资底层逻辑应用 顶层代码低代码配置平台开发结构方式数据存储模块
java·开发语言·数据库·windows·sql