【MySQL】数据库的基本操作

1. 对于库的基本操作

(1) 创建数据库

**语法:**create database [IF NOT EXISTS] 数据库名 ;

**[IF NOT EXIT] :**中括号号包含的这个部分为数据库的可选项,在这里IF NOT EXIT代表没有这个和指定数据库名相同的数据库,就创建一个数据库,如果存在就不创建,方括号不要写到代码中。

**本质:**就是在 var / lib / mysql 中创建一个目录。

编码集:

(1)数据库编码集:数据库未来存储数据所使用的编码集。

(2)数据库效验集:支持数据库进行字段比较的编码格式。本质上是读取数据库的编码方式。

在这里对数据库所做的全部操作,都需要保证操作和编码必须是一致的。

(2) 删除数据库

drop database [IF NOT EXISTS] 数据库名 ;

**本质:**就是在 var / lib / mysql 中删除一个目录。一般情况下要做好数据库的备份工作不要误删。

(3) 查看字符集和效验规则

**查看编码集语法:**show variables like 'character_set_database' ;

**查看效验集语法:**show variables like 'collation_database' ;

一般在创建数据库时,如果没有写效验规则,数据库会以配制文件里的效验规则创建数据库。

对于一个数据库来说,效验规则不同,查出来的结果就有可能不同,比如UTF-8_cin 是区分大小写的,而UTF-8_bin 是不区分大小写的。

(4) 查看数据库

(1)查看所有的数据库

语法:show databases;

(2) 查看特定的数据库

查看特定的数据库必须加上 use 选中特定的关键字。

并且可以使用 **show tables;**来查看某个数据库中的所有表

(3) 查看自己处在哪一个数据库

语法:使用 select database()函数来查看

(3) 查看创建数据库时采用的命令

语法:show create database 数据库名

后面的/**/的内容代表着如果数据库的版本大于40100就采用后面的编码模式。

(5) 修改数据库

语法:alter database 数据库名

还可以修改数据库的编码集

(6) 数据库的备份

因为在Linux操作系统下的数据库本质上就是一个目录,所以可不可以采用直接拷贝这个数据库目录的方式进行备份呢?

答案是可以的,但是因为恢复数据库时,可能会出现版本不一致的问题,所以这里最好不要使用直接拷贝的方式来进行备份操作。

一般在进行数据库备份时,会采用mysqldump工具进行备份,语法如下所示。

数据库整体备份:mysqldump -P端口号 -u用户名 -p密码 -B数据库名 > 数据库备份的文件路径

只对其中几张表备份:mysqldump -u用户名 -p 数据库名 表1 表2> 数据库备份的文件路径

备份多个数据库:mysqldump -u用户名 ​-p密码 -B 数据库1 数据库2 ... > 数据库存放路径

注意:如果备份数据库库时没有带-B属性,在恢复数据库时,需要先创建空的数据库再进行还原。

如果不知道端口号是什么可以使用 mysql> show global variables like 'port';

命令进行查看。

(7) 数据库的还原

语法:source 数据库目录的地址

本质上是将被恢复数据库曾经的全部操作,在一个新的数据库中重新进行一遍。

(8) 查看数据库的连接情况

语法:show processlist;

可以查看哪些人连接到了数据库。

2.对于表的基本操作

(1)创建表

语法:

CREATE TABLE 表名(

属性名1 数据类型,

属性名2 数据类型,

);character set 字符集 collate 效验规则 engine 存储引擎;

说明:

character set 为字符集,如果没有指定字符集,则一所在数据库的字符集为准。

collate 效验规则,如果没有指定效验规则,则以数据库的效验规则为准。

演示:

注意:

使用不同的存储引擎创建表的时候,创建出原来的文件个数可能不同,如下图所示,使用innoDB所创建出的文件是两个,而myisam创建出的文件是3个,因为innoDB是将数据和索引放在一起存储的,而myisam是分开存储的。

(2)查看表

(1)查看所在的数据库

语法:select database();

(2)查看该数据库的所有表、

语法:show tables;

(3)查看具体某一张表的信息

语法:desc 表名;(desc 可以理解为describe的简称)

(4)表的具体含义如下图所示

(3)修改表

在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。

以下是修改表的语法规则:

加属性: ALTER TABLE 表名 ADD 想要添加的属性 数据类型 after 放在那个属性的后面(可不写);

改某属性: ALTER TABLE 表名 MODIfy 想要添加的属性 数据类型 ;

删除某属性: ALTER TABLE 表名 DROP 列名;

修改表的名字: ALTER TABLE 被改表名 rename to 新表名;
修改属性名字: ALTER TABLE 被改表名 name 旧属性名 新属性名 新属性数据类型;

(4)删除表

语法: DROP TABLE 被删除的表名;

注意:不要轻易修改和删除表!!!!

数据库是非常接近底层的,数据库但凡一边所有和数据库相关的代码都需要修改!!!

相关推荐
时序数据说8 分钟前
时序数据库IoTDB在航空航天领域的解决方案
大数据·数据库·时序数据库·iotdb
.生产的驴22 分钟前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
AnsenZhu34 分钟前
2025年Redis分片存储性能优化指南
数据库·redis·性能优化·分片
oydcm1 小时前
MySQL数据库概述
数据库·mysql
oioihoii1 小时前
C++23中if consteval / if not consteval (P1938R3) 详解
java·数据库·c++23
带娃的IT创业者1 小时前
《AI大模型趣味实战》基于RAG向量数据库的知识库AI问答助手设计与实现
数据库·人工智能
husterlichf2 小时前
MYSQL 常用数值函数 和 条件函数 详解
数据库·sql·mysql
我的golang之路果然有问题2 小时前
快速了解redis,个人笔记
数据库·经验分享·redis·笔记·学习·缓存·内存
卡皮巴拉爱吃小蛋糕3 小时前
MySQL的MVCC【学习笔记】
数据库·笔记·mysql
农民也会写代码3 小时前
dedecms织梦arclist标签noflag属性过滤多个参数
开发语言·数据库·sql·php·dedecms