首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql sqlmode设置

基础概念

MySQL的sql_mode是一个系统变量,它定义了MySQL服务器应支持的SQL语法和数据校验规则。sql_mode可以确保数据的完整性和一致性,同时也可以影响服务器的行为。

相关优势

  1. 数据完整性:通过设置严格的sql_mode,可以确保插入的数据符合预期的格式和类型。
  2. 一致性:在不同的数据库服务器之间保持一致的SQL行为。
  3. 安全性:某些sql_mode设置可以防止SQL注入攻击。

类型

MySQL的sql_mode可以设置为多种模式,包括但不限于:

  • ONLY_FULL_GROUP_BY:要求SELECT语句中的GROUP BY子句必须包含SELECT列表中的所有非聚合列。
  • NO_ZERO_IN_DATE, NO_ZERO_DATE:禁止插入零日期(如'0000-00-00')。
  • STRICT_TRANS_TABLES, STRICT_ALL_TABLES:在事务表或所有表中启用严格模式,插入非法值时会引发错误。
  • ERROR_FOR_DIVISION_BY_ZERO:除以零时产生错误。
  • NO_AUTO_CREATE_USER:禁止创建密码为空的用户。
  • NO_ENGINE_SUBSTITUTION:如果指定的存储引擎不可用,则产生错误,而不是使用默认引擎。

应用场景

  1. 开发环境:在开发环境中,通常会设置较严格的sql_mode,以确保代码质量和数据完整性。
  2. 生产环境:在生产环境中,根据业务需求和安全策略,可能会调整sql_mode以平衡性能和安全性。

常见问题及解决方法

问题:为什么设置了ONLY_FULL_GROUP_BY后,某些查询会失败?

原因ONLY_FULL_GROUP_BY模式要求SELECT列表中的所有非聚合列必须在GROUP BY子句中出现。如果查询不满足这个条件,就会失败。

解决方法

  1. 修改查询,确保SELECT列表中的所有非聚合列都在GROUP BY子句中。
  2. 如果不需要严格模式,可以临时禁用ONLY_FULL_GROUP_BY
代码语言:txt
复制
-- 查看当前的sql_mode
SHOW VARIABLES LIKE 'sql_mode';

-- 临时禁用ONLY_FULL_GROUP_BY
SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));

问题:为什么插入零日期会失败?

原因NO_ZERO_IN_DATENO_ZERO_DATE模式禁止插入零日期。

解决方法

  1. 修改插入的数据,避免插入零日期。
  2. 如果需要插入零日期,可以临时禁用这些模式。
代码语言:txt
复制
-- 临时禁用NO_ZERO_IN_DATE和NO_ZERO_DATE
SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'NO_ZERO_IN_DATE',''));
SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'NO_ZERO_DATE',''));

参考链接

通过以上内容,你应该对MySQL的sql_mode有了全面的了解,包括其基础概念、优势、类型、应用场景以及常见问题的解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

mysql5.7在使用group by的注意事项

mysql5.7在使用group by的注意事项 1、问题描述 2、解决方案(一): 3、解决方案(二) 4、解决方案(三) 1、云数据库修改方案: 2、本地数据库修改方案: 1、问题描述 先看一个sql...语句报错: select * from oilDaily group by wellId 这是因为在mysql5.7中开启了sql_mode中的“only_full_group_by”,而这个在执行以往版本中带有...云数据库,修改方式如下: 1、云数据库修改方案: 点击管理 点击参数设置 找到sql_mode选项 去掉ONLY_FULL_GROUP_BY的勾选。...,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION' 你设置上面的值最好用select...@@global.sqlmode查一下,再将ONLY_FULL_GROUP_BY去掉,将剩下的赋值给sqlmode即可。

60320
  • mysql乱码设置

    MySQL默认字符编码的设置 MySQL的默认编码是Latin1,不支持中文,那么如何修改MySQL的默认编码呢,下面以UTF-8为例来说明  需要注意的是,要修改的地方非常多,相应的修改方法也很多...下面是一种最简单最彻底的方法:  一、Windows  1、中止MySQL服务  2、在MySQL的安装目录下找到my.ini,如果没有就把my-medium.ini复制为一个my.ini...即可  3、打开my.ini以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭  4、启动MySQL服务  二、Linux... 1、中止MySQL服务(bin/mysqladmin -u root shutdown)  2、在/etc/下找到my.cnf,如果没有就把MySQL的安装目录下的support-files...服务(bin/mysqld_safe &)  非常简单,这样的修改一劳永逸,今后MySQL一切相关的默认编码均为UTF-8了,创建新表格的时候无需再次设置  需要注意的是,当前数据库中已经存在的数据仍保留现有的编码方式

    3.8K60

    WAMP中的mysql设置密码 WAMP中的mysql设置密码密码

    WAMP中的mysql设置密码密码 WAMP安装好后,mysql密码是为空的,那么要如何修改呢?其实很简单,通过几条指令就行了,下面我就一步步来操作。 1、首先,通过WAMP打开mysql控制台。...2、然后输入“use mysql”,意思是使用mysql这个数据库,提示“Database changed”就行。...3、然后输入要修改的密码的sql语句 update mysql.user set authentication_string=password('root') where user='root' ; 即可...5、对PHPMYADMIN的设置Mysql修改好密码后,还要对phpmyadmin进行简要的配置才能使用phpmyadmin正常访问mysql。...auth_type'] = 'http';cfg['Servers'][i]['user'] = 'root';cfg['Servers'][i]['password'] = 'root';-----你设置的密码

    23.3K30
    领券