`
gaojingsong
  • 浏览: 1202693 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

【一条通用sql因为sql_mode引发的错误】

阅读更多

问题背景:用到GROUP BY 语句查询5.7版本时com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'col_user_6.a.START_TIME' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by错误

 

 

一、查看与设置

查看当前连接会话的sql模式:

mysql> select @@session.sql_mode;

 

或者从环境变量里取

mysql> show variables like "sql_mode";

 

 查看全局sql_mode设置:

mysql> select @@global.sql_mode; 

只设置global,需要重新连接进来才会生效

 

设置

mysql> set sql_mode='';

mysql> set global sql_mode='NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES';

 

 

mysql5.0以上版本支持三种sql_mode模式:ANSI、TRADITIONAL和STRICT_TRANS_TABLES。 

ANSI模式:宽松模式,对插入数据进行校验,如果不符合定义类型或长度,对数据类型调整或截断保存,报warning警告。 

TRADITIONAL模式:严格模式,当向mysql数据库插入数据时,进行数据的严格校验,保证错误数据不能插入,报error错误。用于事物时,会进行事物的回滚。 

STRICT_TRANS_TABLES模式:严格模式,进行数据的严格校验,错误数据不能插入,报error错误。 

 

 

 

sql_mode常用值如下: 

ONLY_FULL_GROUP_BY

对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中

 

NO_AUTO_VALUE_ON_ZERO

该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户 希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。

 

STRICT_TRANS_TABLES

在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制

 

NO_ZERO_IN_DATE

在严格模式下,不允许日期和月份为零

 

NO_ZERO_DATE

设置该值,mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告。

 

ERROR_FOR_DIVISION_BY_ZERO

在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。如 果未给出该模式,那么数据被零除时MySQL返回NULL

 

NO_AUTO_CREATE_USER

禁止GRANT创建密码为空的用户

 

NO_ENGINE_SUBSTITUTION

如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常

 

PIPES_AS_CONCAT

将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似

 

ANSI_QUOTES

启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符

 

0
1
分享到:
评论

相关推荐

    使用ADO访问sql several 2000数据库

    4. **处理结果**:查询结果将保存在`Recordset`对象中,可以通过遍历该对象来处理每一条记录。 #### 示例代码 ```vb Dim conn As New ADODB.Connection Dim rs As New ADODB.Recordset ' 设置连接字符串 conn....

    MySQL数据库开发期末复习题.doc

    MySQL数据库开发期末复习题 ...21. 查看全局SQL模式:查看全局SQL模式的命令是select global.sql_mode。 22. 非严格模式:在非严格模式下处理无效值时,MySQL会基于列定义的限制隐含值来执行类型转化。

    Oracel Proc开发

    Oracle Proc 是一种嵌入式C语言的编程方式,它允许开发者在C程序中直接执行SQL语句,类似于Informix的ESQ/C。这种方式使得开发者能够利用C语言的强大功能结合Oracle数据库的操作,提高程序效率和灵活性。 1. **数组...

    完整word版-《MySQL数据库开发》期末复习试题1.doc

    1. 查看全局 SQL 模式的命令:select @@global.sql_mode 是查看全局 SQL 模式的命令。 严格模式 1. 严格模式:在严格模式下,拒绝超出范围的值,拒绝不正确数据类型的值,拒绝没有缺省值的非空列。 VARCHAR 类型 ...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    SQL(Structured Query Language)结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。同时也是数据库脚本文件的扩展名。  SQL语言主要包含5个部分  数据定义...

    超级有影响力霸气的Java面试题大全文档

    在实现中,assertion就是在程序中的一条语句,它对一个boolean表达式进行检查,一个正确程序必须保证这个boolean表达式的值为true;如果该值为false,说明程序已经处于不正确的状态下,系统将给出警告或退出。...

    ASP.NET2.0学习5--N层代码示例

    此外,还提供了一条插入语句作为示例,用于演示如何向`Customers`表中插入一条记录。这有助于开发者快速了解如何在实际开发中操作数据库。 #### 二、配置文件(web.config)详解 配置文件`web.config`是ASP.NET...

    springmybatis

    创建用户表,并插入一条测试数据 程序代码 程序代码 Create TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `userName` varchar(50) DEFAULT NULL, `userAge` int(11) DEFAULT NULL, `userAddress` ...

    Adodc控件的属性详解

    取值为:0(移到第一条记录)、1(停留在当前记录)。 5. CacheSize 属性:该属性获得或设置作为游览集合的缓存来保留的行数。 6. Caption 属性:该属性设置控件的标题。 7. CommandTimeout 属性:该属性等待命令...

    计算机专业英语_考试题目.pdf

    13. **汇编语言 (Assembly Language)**:一种低级编程语言,每条指令对应机器码的一个操作,便于程序员理解硬件操作。 14. **标准化 (Standardize)**:制定和遵循共同的规则、标准或规范,以确保不同系统、设备或...

    2021-2022计算机二级等级考试试题及答案No.18997.docx

    - **ATM** (Asynchronous Transfer Mode):一种面向连接的数据传输技术,主要用于局域网和广域网。 - **TCP/IP** (Transmission Control Protocol/Internet Protocol):互联网协议族的核心组成部分,定义了设备...

    WPF_开发教程(_中文版).

    - **CLR(Common Language Runtime)**:WPF充分利用了CLR的优势,如内存管理、错误处理和通用类型系统等,同时也兼顾了性能需求。 - **milcore**:这是WPF体系结构中的非托管部分,主要用于实现与DirectX的紧密集成...

    VB控件大全属性详解.doc

    - `0 adDoMoveFirst`:移动到第一条记录。 - `1 adStayBOF`:保持在文件开始处。 - **用途**:定义当游标位于记录集起始位置时的操作。 - **示例**:`Adodc1.BOFAction = adDoMoveFirst` #### CacheSize **说明**...

    Linux命令术语全称

    Berkely 养的一条狗, 喜欢对邮递员汪汪叫。** - **含义**:电子邮件通知工具。 - **用途**:提示有新邮件到达。 22. **cal=CALendar** - **含义**:日历命令。 - **用途**:显示当前月份的日历。 23. **cat=...

    C#程序单词注释汇总

    - 查找并修复程序错误的过程。 61. **Check**: - 检查。 - 验证某些条件是否满足的过程。 62. **Allocate**: - 分配。 - 为对象或数据分配内存空间。 63. **Assign**: - 赋值。 - 将一个值赋给变量或属性...

    网管教程 从入门到精通软件篇.txt

    Chkdsk 命令还可列出并纠正磁盘上的错误。  含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。  vol [drive:] [ chkdsk [drive:] [/p] [/r]  ...

Global site tag (gtag.js) - Google Analytics