Mysql 文件配置解析
作者:??斜月???? 时间:2024-01-26 10:01:54
前言:
mysql
数据库在日常工作开发中经常用到的存储设备, 之前已经分享了面试过程中经常被问到的mysql
优化的内容,本期就结合mysql
的配置文件进行分析。这里需要说明的是, 在windows
系统的配置文件为 my.ini
, 而在Linux
上的配置文件为my.cnf
。
client 端配置
在客户端的配置文件 主要包括 mysql
的服务端口,已经 mysql
连接通信文件,以及客户端连接的字符集。
[client]
#客户端设置
port=3306
socket=/data/mysql/data/mysql.sock
default-character-set=utf8mb4
mysqld 端配置
# 服务端文件配置
[mysqld]
# mysql 服务启动时的用户
user=mysql
# 服务启动的默认端口
port=3306
#mysql的客户端和服务端之间建立通信时需要指定一个通信stock文件
socket= /data/mysql/data/mysql.sock
#mysql服务的ID,在主从同步时来标记服务的唯一身份
server-id=1
# 端口的ip绑定,这里和redis的端口绑定类似,如果是0.0.0.0标识允许所有的远程访问,127.0.0.1表示只能是本地访问,如果固定ip则只能接受改ip的远程访问。
bind-address = 0.0.0.0
# linux 中一切皆文件,mysql服务启动后会记录进程id到改文件中,用于记录服务的运行情况
pid-file=/data/mysql/data/mysql.pid
#mysql服务的安装目录
basedir=/usr/local/mysql
#mysql服务的数据数据存放目录
datadir=/data/mysql/data/
#数据库系统磨人的字符集合排序方式,这里说一下ci和cs的区别,就是大小写敏感和不敏感 ci 就是 case ignore cs 就是 case senstive
character_set_server=utf8mb4
collation_server=utf8mb4_general_ci
其他设置
#表名称和表字段是否区分大小写1 表示区分大小写,0表示区分大小写
lower_case_table_name=1
# 创建新表时使用的默认数据库引擎
default-storage-engine=INNODB
sql_mode
sql_mode
是 mysql
中一个重要的配置项,其定义了支持的 sql
语法和数据校验规则。
sql 模式设置: ANSI 是宽松模式,对数据插入进行校验,如果不符合数据定义和长度,对数据类型调整或者截断保存,给出 warning 警告。STRICT_TRANS_TABLES 严格模式,严格校验保证错误格式的数据不能插入,报 error 错误,只对事务操作起作用,非事务操作不起作用。TRADITIONAL 严格模式,在插入数据时进行严格校验,保证错误数据不能插入并报 error 错误。作用于事务时会回滚事务。
是否接受日期格式为 0。NO_ZERO_DATE 是否允许 '0000-00-00' 日期 * 入。如果不启用,则 '0000-00-00' 允许插入没有 waring 提示信息。如果启用配置则 '0000-00-00' 允许插入有提示信息。如果是严格模式且启用配置,则'0000-00-00' 不允许插入并产生 error 错误。但是 insert ingore 或者 update ignore 的 sql 除外。NO_ZERO_IN_DATE 和 NO_ZERO_DATE 是类似的,只不过接受的日期为 '2010-00-01' 或者 '2010-01-00', 而不是 '0000-00-00'。
ONLY_FULL_GROUP_BY 该模式下对于 group by 聚合操作,在 select 中的列,如果没有在 group by 中出现,将会认为这个 sql 不合法。
NO_AUTO_CREATE_USER 禁止创建密码为空的用户。
NO_ENGINE_SUBSTITUTION 当存储引擎禁用或者未解析时,使用存储引擎就会报错。
NO_AUTO_VALUE_ON_ZERO 自增数据列设置,默认情况下,插入 0 或者 null 则代表下一个自增值,如果用户希望插入数据为 0 但是该列为自增,此时需要设置改配置。
Mysql InnoDB 的内存结构 在 insert 或者 update 数据时,如果数据除零,则产生错误而非警告。
常用的配置如下所示:
sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,
ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
来源:https://juejin.cn/post/7056349239558799374
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
tensorflow创建变量以及根据名称查找变量
解决pycharm不能自动补全第三方库的函数和属性问题
使用Python第三方库pygame写个贪吃蛇小游戏
![](https://img.aspxhome.com/file/2023/1/76701_0s.png)
Vuex简单入门
![](https://img.aspxhome.com/file/2023/6/130146_0s.png)
面试官常问之说说js中var、let、const的区别
教你给《羊了个羊》配置一套智能客服系统
![](https://img.aspxhome.com/file/2023/8/117538_0s.jpg)
Python中的random函数实例详解
![](https://img.aspxhome.com/file/2023/5/87555_0s.jpg)
Linux Centos 下使用yum 命令安装mysql实现步骤
zabbix监控mysql的实例方法
![](https://img.aspxhome.com/file/2023/7/93897_0s.jpg)
Pytorch中使用TensorBoard详情
![](https://img.aspxhome.com/file/2023/3/115423_0s.gif)
Python实现一个转存纯真IP数据库的脚本分享
![](https://img.aspxhome.com/file/2023/8/103288_0s.jpg)
python简单获取数组元素个数的方法
详解Python的迭代器、生成器以及相关的itertools包
Python 生成 -1~1 之间的随机数矩阵方法
![](https://img.aspxhome.com/file/2023/2/82682_0s.jpg)
解决Pytorch自定义层出现多Variable共享内存错误问题
Python基于jieba分词实现snownlp情感分析
![](https://img.aspxhome.com/file/2023/0/63590_0s.jpg)
python 装饰器功能以及函数参数使用介绍
![](https://img.aspxhome.com/file/2023/4/67794_0s.png)