问题背景:用到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后,不能用双引号来引用字符串,因为它被解释为识别符
相关推荐
4. **处理结果**:查询结果将保存在`Recordset`对象中,可以通过遍历该对象来处理每一条记录。 #### 示例代码 ```vb Dim conn As New ADODB.Connection Dim rs As New ADODB.Recordset ' 设置连接字符串 conn....
MySQL数据库开发期末复习题 ...21. 查看全局SQL模式:查看全局SQL模式的命令是select global.sql_mode。 22. 非严格模式:在非严格模式下处理无效值时,MySQL会基于列定义的限制隐含值来执行类型转化。
Oracle Proc 是一种嵌入式C语言的编程方式,它允许开发者在C程序中直接执行SQL语句,类似于Informix的ESQ/C。这种方式使得开发者能够利用C语言的强大功能结合Oracle数据库的操作,提高程序效率和灵活性。 1. **数组...
1. 查看全局 SQL 模式的命令:select @@global.sql_mode 是查看全局 SQL 模式的命令。 严格模式 1. 严格模式:在严格模式下,拒绝超出范围的值,拒绝不正确数据类型的值,拒绝没有缺省值的非空列。 VARCHAR 类型 ...
SQL(Structured Query Language)结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。同时也是数据库脚本文件的扩展名。 SQL语言主要包含5个部分 数据定义...
在实现中,assertion就是在程序中的一条语句,它对一个boolean表达式进行检查,一个正确程序必须保证这个boolean表达式的值为true;如果该值为false,说明程序已经处于不正确的状态下,系统将给出警告或退出。...
此外,还提供了一条插入语句作为示例,用于演示如何向`Customers`表中插入一条记录。这有助于开发者快速了解如何在实际开发中操作数据库。 #### 二、配置文件(web.config)详解 配置文件`web.config`是ASP.NET...
创建用户表,并插入一条测试数据 程序代码 程序代码 Create TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `userName` varchar(50) DEFAULT NULL, `userAge` int(11) DEFAULT NULL, `userAddress` ...
取值为:0(移到第一条记录)、1(停留在当前记录)。 5. CacheSize 属性:该属性获得或设置作为游览集合的缓存来保留的行数。 6. Caption 属性:该属性设置控件的标题。 7. CommandTimeout 属性:该属性等待命令...
13. **汇编语言 (Assembly Language)**:一种低级编程语言,每条指令对应机器码的一个操作,便于程序员理解硬件操作。 14. **标准化 (Standardize)**:制定和遵循共同的规则、标准或规范,以确保不同系统、设备或...
- **ATM** (Asynchronous Transfer Mode):一种面向连接的数据传输技术,主要用于局域网和广域网。 - **TCP/IP** (Transmission Control Protocol/Internet Protocol):互联网协议族的核心组成部分,定义了设备...
- **CLR(Common Language Runtime)**:WPF充分利用了CLR的优势,如内存管理、错误处理和通用类型系统等,同时也兼顾了性能需求。 - **milcore**:这是WPF体系结构中的非托管部分,主要用于实现与DirectX的紧密集成...
- `0 adDoMoveFirst`:移动到第一条记录。 - `1 adStayBOF`:保持在文件开始处。 - **用途**:定义当游标位于记录集起始位置时的操作。 - **示例**:`Adodc1.BOFAction = adDoMoveFirst` #### CacheSize **说明**...
Berkely 养的一条狗, 喜欢对邮递员汪汪叫。** - **含义**:电子邮件通知工具。 - **用途**:提示有新邮件到达。 22. **cal=CALendar** - **含义**:日历命令。 - **用途**:显示当前月份的日历。 23. **cat=...
- 查找并修复程序错误的过程。 61. **Check**: - 检查。 - 验证某些条件是否满足的过程。 62. **Allocate**: - 分配。 - 为对象或数据分配内存空间。 63. **Assign**: - 赋值。 - 将一个值赋给变量或属性...
Chkdsk 命令还可列出并纠正磁盘上的错误。 含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。 vol [drive:] [ chkdsk [drive:] [/p] [/r] ...