gpt4 book ai didi

MySQL:永久设置 sql_mode

转载 作者:行者123 更新时间:2023-11-29 16:04:13 29 4
gpt4 key购买 nike

通过MySQL命令行客户端,我尝试设置全局mysql_mode:

SET GLOBAL sql_mode = TRADITIONAL;

这适用于当前 session ,但在我重新启动服务器后,sql_mode 将返回到其默认值:“”,一个空字符串。

如何将 sql_mode 永久设置为传统?

如果相关,MySQL 是 WAMP 包的一部分。

谢谢。

最佳答案

MySQL sql_mode “传统”,又名“严格模式”,由 the MySQL docs 定义。如:

“give an error instead of a warning” when inserting an incorrect value into a column.

以下是如何确保您的 sql_mode 设置为“传统”

首先,检查您当前的设置:

mysql
mysql> SELECT @@GLOBAL.sql_mode;
+-------------------+
| @@GLOBAL.sql_mode |
+-------------------+
| |
+-------------------+
1 row in set (0.00 sec)

这返回空白,默认值,这很糟糕:您的 sql_mode 未设置为“TRADITIONAL”。

因此编辑配置文件:

sudo vim /etc/mysql/my.cnf

在标记为[mysqld]的部分中添加此行:sql_mode="TRADITIONAL"(如fancyPants指出的)

然后重新启动服务器:

sudo service mysql restart

然后再次检查:

mysql
mysql> SELECT @@GLOBAL.sql_mode;
+------------------------------------------------------------------------------------------------------------------------------------------------------+
| @@GLOBAL.sql_mode |
+------------------------------------------------------------------------------------------------------------------------------------------------------+
| STRICT_TRANS_TABLES,STRICT_ALL_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,TRADITIONAL,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
+------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

成功!你现在已经是黄金了。

关于MySQL:永久设置 sql_mode,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55888314/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com