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

标签:Mysql,文件,配置
0
投稿

猜你喜欢

  • tensorflow创建变量以及根据名称查找变量

    2023-08-13 10:13:06
  • 解决pycharm不能自动补全第三方库的函数和属性问题

    2023-10-10 09:46:16
  • 使用Python第三方库pygame写个贪吃蛇小游戏

    2021-05-19 11:08:37
  • Vuex简单入门

    2024-05-02 16:58:26
  • 面试官常问之说说js中var、let、const的区别

    2024-05-09 15:06:58
  • 教你给《羊了个羊》配置一套智能客服系统

    2022-01-25 21:33:36
  • Python中的random函数实例详解

    2021-01-09 13:01:49
  • Linux Centos 下使用yum 命令安装mysql实现步骤

    2024-01-28 02:24:42
  • zabbix监控mysql的实例方法

    2024-01-19 06:39:56
  • Pytorch中使用TensorBoard详情

    2023-07-11 01:14:56
  • Python实现一个转存纯真IP数据库的脚本分享

    2024-01-17 16:43:38
  • python简单获取数组元素个数的方法

    2023-03-08 15:39:29
  • 详解Python的迭代器、生成器以及相关的itertools包

    2022-07-24 01:03:44
  • Python 生成 -1~1 之间的随机数矩阵方法

    2023-08-03 17:35:22
  • 解决Pytorch自定义层出现多Variable共享内存错误问题

    2023-12-14 14:43:46
  • Python基于jieba分词实现snownlp情感分析

    2023-11-14 21:43:38
  • python 装饰器功能以及函数参数使用介绍

    2022-04-03 05:12:32
  • Request.ServerVariables应用实例

    2008-03-11 11:57:00
  • 详解Mysql基础语法的使用

    2024-01-28 07:50:05
  • asp HTTP_X_FORWARDED_FOR和REMOTE_ADDR

    2010-07-02 12:33:00
  • asp之家 网络编程 m.aspxhome.com