一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

db文件怎样修改_详解MySQL数据库中db.opt文件含义及作用

时间:2026-06-19 09:04:54 编辑:袖梨 来源:一聚教程网

概述

MySQL数据库存放数据目录里的db.opt文件是MySQL建库过程中自动生成的。

细心的朋友可能会发现有时候在MySQL数据库的某些库目录下有个db.opt文件,那这个文件是干什么用的呢?如果你用记事本等编辑器打开看的话,内容很简单,是用来记录该库的默认字符集编码和字符集排序规则用的。


db.opt

MySQL的每个数据库目录中有一个文件db.opt,该文件主要 用来存储当前数据库的默认字符集和字符校验规则。

default-character-set=utf8default-collation=utf8_general_ci

该文件中存储的是创建数据库时默认的字符集和字符集校验规则,则该数据库在以后创建表时如果没有指定字符集和校验规则,则该表的这两个属性将去自这两个表。

7e4938a5a98ec498b7ab2a6a20eabeab.png

MySQL源码:

/* Set table default charset, if not setSYNOPSISset_table_default_charset()create_info Table create informationDESCRIPTIONIf the table character set was not given explicitely,let’s fetch the database default character set andapply it to the table. */​static void set_table_default_charset(THD *thd,HA_CREATE_INFO *create_info, char *db){if (!create_info->default_table_charset){HA_CREATE_INFO db_info;load_db_opt_by_name(thd, db, &db_info);create_info->default_table_charset= db_info.default_table_charset;}


字符集和字符集校验规则

创建数据库时指定字符集和字符集校验规则:

create database if not exists test default charset utf8 default collate utf8_general_ci;430791686750c10eaa2ea09c208c089a.pngd3d9c3c9a7da93c60b46f893770746f5.png

修改数据库的字符集和字符集校验规则:

alter database test default [charset|character set ] latin1 default collate latin1_swedish_ci;

创建数据库create database

CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name[create_specification] …create_specification:[DEFAULT] CHARACTER SET [=] charset_name| [DEFAULT] COLLATE [=] collation_name

也可以通过alter database修改

ALTER {DATABASE | SCHEMA} [db_name]alter_specification …alter_specification:[DEFAULT] CHARACTER SET [=] charset_name| [DEFAULT] COLLATE [=] collation_name


总结

1、create database时会自动生成一个文件db.opt,存放的数据库的默认字符集,show create database时显示数据库默认字符集即db.opt中字符集。

2、这个文件丢失不影响数据库运行,该文件丢失之后新建表时,找不到数据库的默认字符集,就把character_set_server当成数据库的默认字符集,show create database时显示character_set_server字符集。

后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~

25f979a49e3d3a0a4201e4cf96db3867.gif

热门栏目