跳转至

Basic Operations

SQL 语句分类

  • DDL[data definition language] 数据定义语言,用来维护存储数据的结构。

如:create,drop,alter

  • DML[data manipulation language] 数据操纵语言,用来对数据进行操作

如: insert,delete,update

DML中又单独分了一个DQL,数据查询语言,代表指令: select

  • DCL[Data Control Language] 数据控制语言,主要负责权限管理和事务

如: grant,revoke,commit

库操作

创建库

create database [if not exists] db_name  [create_specification [,
create_specification] ...];

create_specification:
    [DEFAULT] character set charset_name
    [DEFAULT] collate collation_name

创建库在 Linux 就是一个文件目录,在路径 /var/lib/mysql 下。

Image title
Image title

数据库的编码集:字符集和校验集。

字符集:数据库存数据时采用的编码方式。

校验集:从数据库读数据时的编码方式。

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

show variables like 'character_set_database';
show variables like 'collation_database';

查看数据库支持的字符集

show charset;

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

show collation;

在创建数据库时,没有指定的话,会使用配置文件中的默认字符集和校验规则。指定的语法如下:

create database if not exists d2 charset=utf8mb4 collate utf8mb4_0900_ai_ci;

查看数据库

显示所有数据库:

show databases;

显示创建语句:

show create database [数据库名];
Image title
  • MySQL 建议我们关键字使用大写,但是不是必须的。

  • 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字

  • /!40100 default.... / 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话。

使用 use 可以让我使用一个指定的数据库:

use [数据库名]

使用如下命令可以查看当前正在使用的数据库:

select database();

使用如下命令也可也查看当前状态。

status;

删除库

DROP DATABASE [IF EXISTS] db_name;

修改数据库

语法:

alter database db_name [alter_spacification [,alter_spacification]...]

alter_spacification:
[DEFAULT] character set charset_name
[DEFAULT] collate collation_name

说明: 对数据库的修改主要指的是修改数据库的字符集,校验规则 实例: 将 mytest 数据库字符集改成 gbk

alter database d2 char set gbk;

备份和恢复

这里使用到 mysql 自带的备份工具 mysqldump:

mysqldump -P[mysql服务端口号] -u[用户名] -p [密码] -B [数据库名] >  [数据库备份存储的文件路径]

示例:将mytest库备份到文件(退出连接)

mysqldump -P3306 -uroot -p -B d2 > d2.sql
Image title

我们可以大致看一下 d2.sql 文件内容:

Image title

就是我们创建数据库时的一条条指令。我们回复数据库时,就是让 mysql 一条一条执行这些 sql 语句。现在我们删掉 d2 数据库。只需要在 mysql 下使用 source 指令,mysql 就会执行上述的每一条指令,为我们回复源数据库:

Image title
Image title

除了数据库也可以备份表。

mysqldump -u root -p 数据库名 表名1 表名2 > [数据库备份存储的文件路径]

查询连接情况

show processlist

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