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
相关推荐
ClouGence14 分钟前
TiCDC 够用吗?聊聊 TiDB 同步的几个关键问题
数据库·分布式·后端
iuvtsrt29 分钟前
SQL如何高效提取大表前几行:分页查询与OFFSET优化
jvm·数据库·python
彳亍10139 分钟前
如何用 Dask 替代 Pandas 实现高效 Excel 数据处理
jvm·数据库·python
音符犹如代码40 分钟前
Docker 一键部署带有 TimescaleDB 插件的 PostgreSQL
java·运维·数据库·后端·docker·postgresql·容器
程序leo源43 分钟前
Qt信号与槽深度详解
c语言·开发语言·数据库·c++·qt·c#
2301_783848651 小时前
c++怎么把多个变量一次性写入二进制文件_结构体对齐与write【实战】
jvm·数据库·python
wang3zc1 小时前
如何在 WooCommerce 后台按订单总金额精准筛选订单
jvm·数据库·python
大得3692 小时前
LangGraph使用
数据库
Mahir082 小时前
Redis 核心机制:数据过期策略与淘汰策略深度解析
数据库·redis·后端·缓存·面试
多敲代码防脱发2 小时前
Spring进阶(BeanFactory与ApplicationContext)
java·数据库·spring boot·后端·spring