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
相关推荐
逻辑驱动的ken1 小时前
Java高频面试考点14
开发语言·数据库·算法·哈希算法
qq_189807031 小时前
Less如何处理CSS长文本换行_封装Mixin解决不同场景需求
jvm·数据库·python
HHHHH1010HHHHH2 小时前
CSS如何处理带有状态切换的折叠菜单_利用BEM修饰符管理状态
jvm·数据库·python
2401_871696522 小时前
如何在响应式网页中水平居中表单(CSS 绝对定位居中方案)
jvm·数据库·python
2301_775148152 小时前
CSS如何减少对HTML结构依赖_利用BEM命名保持样式的逻辑独立
jvm·数据库·python
sinat_383437362 小时前
HTML函数调试需要高性能电脑吗_调试环境硬件需求技巧【指南】
jvm·数据库·python
解救女汉子2 小时前
Nginx如何配置phpMyAdmin访问_反向代理设置方法
jvm·数据库·python
qq_206901392 小时前
Navicat导出CSV文件数据为空如何解决_过滤条件与权限排查
jvm·数据库·python
m0_588758482 小时前
高效实现分组内跨行时间戳匹配:为每组生成布尔标记列 user_rejects
jvm·数据库·python