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
相关推荐
唔6618 小时前
(二)补充完整的数据库、中间件、MQTT、JAR后台和Web前端的部署脚本,全部一键自动化。
数据库·中间件·jar
六月雨滴18 小时前
Oracle 内存优化
数据库·oracle
学代码的真由酱18 小时前
MySQL数据库进阶-数据库设计实践-Java
数据库·mysql·数据库设计
遇事不決洛必達19 小时前
【数据库系列】本地映射云服务器Mysql的方法
服务器·数据库·mysql·定时任务
海鸥-w19 小时前
用python (fastapi)做项目第一天创建项目结构,数据建表,ORM配置安装,写第一个接口
数据库·python·fastapi
zfoo-framework19 小时前
通过redis-cli+lua脚本查询redis数据
数据库·redis·lua
牛栓柱19 小时前
【后端实战】用 Supabase + React/TS 零成本构建高并发 Multi-Agent 服务
前端·数据库·人工智能·后端·react.js·前端框架
yuezhilangniao19 小时前
xtr备份prepare到底变化了啥
mysql
yyk的萌19 小时前
创建属于自己的mysql的mcp
mysql·adb·ai·mcp
流烟默19 小时前
腾讯云Centos7.6使用yum安装MySQL8
mysql·centos·腾讯云