【MySQL】数据库增删查改

MySQL数据存储位置:

/var/lib/mysql

📖Note:

var是variable(变量)的缩写,该目录下存放一些经常会变动的文件,比如cache,log file以及一些软件运行产生的文件等

1.创建数据库

语法:create database db_name

创建成功之后,/var/lib/mysql目录下生成对应的数据库目录

打开目录,看一下一个新的数据库中都有什么

可以发现,对于我们新建的数据库test,目前只包含一个文件db.opt,并且这个文件中存放的是我们数据库的编码集校验集

编码集:数据库存储数据时所采用的编码规则

校验集:数据库读取数据时所采用的编码规则


查看数据库的编码集:show variable like 'character _set_database'

查看数据库的校验集:show variable like 'collation_database'

我们新建数据库时,若没有指定编码集和校验集,我们的数据库采用的是系统默认的utf8编码集和对应的utf8_general_ci校验集


当然,创建数据库时也可以自己指定编码集和校验集。如下图

📖Note:

  • 编码集和字符集必须相对应,否则读取数据库可能产生错误
  • 使用**show charset;**语句查看支持的编码集和校验集以及对应关系

2.删除数据库

语法:drop database db_name

📖Note:

  • 删库要谨慎

3.数据库备份与恢复

以下指令在shell环境运行

指令:mysqldump -P3306 -u root -p -B db_name(数据库名) > 备份文件的存储路径

📖Note:

  • -B选项:在备份文件中,自动新建数据库,若备份时未添加-B选项,恢复时需要先手动创建一个空数据库,再执行还原语句
  • mysqldump指令的选项说明可以使用man指令查看

在数据库test中创建两个表tb和tb1,并且对表进行一些操作,如下图

我们现在要删除数据库test,删除之前先备份

上图中,我们已经成功备份数据库文件,放在/tmp目录下的test.sql文件,并且在test.sql文件中可以发现,数据库备份其实是备份的SQL语句的执行,而不是具体的数据,当我们恢复数据库时,相当于重新执行了一边原来的SQL语句。


恢复数据库:source 备份文件的存储路径;

当然,也可以备份某个数据库中的表

指令:mysqldump -u root -p db_name(数据库名) tb1_name tb1_name> 备份文件的存储路径

4.查看/修改数据库

我们已经多次使用**show databases;**语句查看创建的数据库列表了,除此之外,以下语句可以帮我们查看数据库创建时的相关信息;

语法:show create database db_name;

以下语句可以帮我们修改数据库的编码集和校验集

语法:alter database db_name charset=(编码集名称) collate (校验集名称);

相关推荐
数据组小组2 小时前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替
用户8307196840827 小时前
MySQL 查询优化 30 条封神技巧:用好索引,少耗资源,查询快到飞起
mysql
Nyarlathotep01138 小时前
事务隔离级别
sql·mysql
悟空聊架构8 小时前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构
IvorySQL8 小时前
PostgreSQL 技术日报 (3月4日)|硬核干货 + 内核暗流一网打尽
数据库·postgresql·开源
Nyarlathotep011311 小时前
SQL的事务控制
sql·mysql
进击的丸子12 小时前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端
用户861782773651812 小时前
MySQL 8.0从库宕机排查实录:中继日志膨胀引发的连锁故障复盘
mysql
NineData1 天前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL1 天前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源