MYSQL操作库

目录

数据库操作

创建数据库

数据库编码集

删除数据库

修改数据库

库的备份与恢复

查看数据库连接情况

数据库表操作

创建表

查看表

修改表结构

删除表


数据库操作

创建数据库

创建数据库的语法如下:

sql 复制代码
create database [if not exists] db_name [create_specification [,
create_specification] ...]

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

character为编码集,collate为设置校验集。

如下所示:

同时查看/var/lib/mysql文件,发现多了一个目录:

创建数据库的本质,是在/var/lib/mysql创建一个目录,也可以通过在/var/lib/mysql目录中新建文件夹来创建数据库,不过这样不推荐。

使用数据库可以用use db_name指令,若要查看用户当前处在哪一个数据库下,可以使用select database()指令;查看数据库创建时的指令为show create database db_name。

数据库编码集

创建数据库的时候,有两个编码集,一个是数据库编码集,一个是数据库校验集。

数据库编码集对应存储数据的编码集,数据库校验集用来支持数据库进行字段比较使用的编码,本质也是一种读取数据库中数据的采用的编码格式。数据库无论对数据做任何操作,都必须保证操作和编码必须是编码一致的。

查看系统默认支持的编码集,命令如下:

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

查看系统默认支持的校验集命令,如下:

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

查看数据库支持的全部字符集:

sql 复制代码
show charset;

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

sql 复制代码
show collation;

删除数据库

删除数据库的命令如下:

sql 复制代码
drop database [if exists] db_name;

删除数据库,本质就是删除对应的目录。

修改数据库

修改数据库的命令如下:

sql 复制代码
alter database db_name
[alter_specification [,alter_specification]...]

库的备份与恢复

数据库备份的命令如下:

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

示例如下所示:

查看对应的sql文件,如下所示:

注意,如果备份一个数据库时,没有带上-B参数,在恢复数据库时,需要先创建空数据库,然后使用数据库,再进行还原。

恢复数据库的指令如下:

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

如果要备份数据库中的几张表,命令如下:

sql 复制代码
mysqldump -u root -p 数据库名 表名1 表名2 > 数据库备份存储的文件路径

如果要备份多个数据库,命令如下:

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

查看数据库连接情况

sql 复制代码
show processlist

如下所示:

数据库表操作

创建表

数据库创建表的操作语法如下:

sql 复制代码
create table [if not exists] table_name (
    field1 datatype [comment '对应的描述'],
    field2 datatype [comment '对应的描述'],
    field3 datatype [comment '对应的描述']
) [character set 字符集 collate 校验规则 engine 存储引擎];

示例如下:

查看对应的数据库文件:

我们发现,不同的存储引擎,对应的文件个数也不一样。

查看表

查看数据库中的表命令如下:

sql 复制代码
show tables;

如果要查看某一个表的详细信息,命令如下:

sql 复制代码
desc tablename;

查看创建表时的详细信息:

sql 复制代码
show create table tablename \G;

其中'\G'代表格式化显示,将不需要的符号去掉。

修改表结构

修改表的命令如下:

sql 复制代码
alter table old_tablename rename to new_tablename;

alter table tablename add (column datatype [DEFAULT expr][,column 
datatype]...);

alter table tablename modify (column datatype [DEFAULT expr][,column 
datatype]...);

alter table tablename drop (column);

alter table tablename change old_columnname new_columnname datatype;

修改相关属性列,是通过直接覆盖来实现的。

删除表

删除表的命令如下:

sql 复制代码
drop table table_name
相关推荐
唐青枫14 小时前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩14 小时前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满87815 小时前
5.Mysql事务隔离级别与锁机制
mysql
笃行3501 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3501 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3501 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H1 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
SelectDB2 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构