MySQL数据库的模式(SQL Mode)是指影响MySQL服务器解析和执行SQL语句方式的设置,这些模式决定了MySQL支持的SQL语法以及数据验证检查,从而允许MySQL在不同的环境中使用,并且可以与其他数据库服务器一起工作。
全局SQL模式与当前SQL模式
1、全局SQL模式:适用于所有连接的客户端,可以通过以下命令查看当前的全局SQL模式:
SELECT @@global.sql_mode;
修改全局SQL模式可以使用以下命令:
SET @@global.sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
或者在MySQL配置文件mysql.ini
中进行永久设置:
[mysqld] sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
2、当前SQL模式:仅适用于当前会话,可以通过以下命令查看当前的当前SQL模式:
SELECT @@sql_mode;
修改当前SQL模式可以使用以下命令:
SET @@sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
SQL模式分类
1、语法支持类:例如ONLY_FULL_GROUP_BY
要求GROUP BY
查询中的列必须出现在SELECT
列表中;ANSI_QUOTES
启用 ANSI 引号,将双引号解释为标识符而不是字符串字面量。
2、数据检查类:例如STRICT_TRANS_TABLES
对事务表实行严格模式;ERROR_FOR_DIVISION_BY_ZERO
在除数为零时产生错误。
常用SQL模式
1、TRADITIONAL(传统模式):在该模式下,当在列中插入不正确的值时,会给出错误而不是警告,如果发生错误,操作会立即终止。
2、STRICT(严格模式):分为STRICT_TRANS_TABLES
(对支持事务的表实行严格模式)和STRICT_ALL_TABLES
(对所有表实行严格模式),在严格模式下,如果不能将给定的值插入到表中,则放弃该语句。
3、ANSI(标准模式):更改操作的语法和行为,使其更适合标准的SQL,启用ANSI_QUOTES
后,不能用双引号来引用字符串,因为它被解释为标识符。
SQL模式的重要性
兼容性:通过选择合适的SQL模式,可以确保MySQL在不同环境下的行为一致,便于与其他数据库系统协同工作。
数据完整性:严格的SQL模式有助于维护数据的完整性,防止不合法的数据插入或更新。
灵活性:不同的应用程序可以根据其需求设置不同的SQL模式,从而实现定制化的数据管理和操作。
MySQL数据库的SQL模式是一个关键设置,它决定了MySQL服务器如何解析和执行SQL语句,通过合理配置SQL模式,可以确保数据库在不同环境下的行为一致,维护数据的完整性,并实现灵活的数据管理。
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。