看mysql手册中模式(SQL_MODE)学到的知识

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 使用phpmyadmin导出sql的时候,常常会出现SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";的语句。通过看sql手册,明白了这里设置的含义。那么可以回答几个疑惑性问题了一、设置sql模式有什么作用?会产生什么方面的影响?模式定义mysql会支持哪些sql语法。


使用phpmyadmin导出sql的时候,常常会出现SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";的语句。通过看sql手册,明白了这里

设置的含义。

那么可以回答几个疑惑性问题了
一、设置sql模式有什么作用?会产生什么方面的影响?
模式定义mysql会支持哪些sql语法。以及应执行哪种数据验证检查。最终达到的目标:适应在不同环境中适应mysql,因为可

以根据各自的程序不同设置对于德sql操作模式。输入如下语句可以知道,当前使用的sql模式,select @@sql_mode

比如,NO_AUTO_VALUE_ON_ZERO模式下,根据字面意思,没有自动增量为0的值。


二、做一个实验:

步骤1.SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO"  您运行的 SQL 语句已经成功运行了。
2. SELECT @@sql_mode
@@sql_mode
 为什么结果是空呢?没有设置成功吗?
原因分析:可能是是在phpmyadmin中运行语句的。因为我在mysql客户端运行结果,能够看到设置后的sql模式结果。此时在

phpmyadmin中却看不到设置好的模式。那一项的结果是空。


3.插入一条数据
INSERT INTO `julebu`.`matches` (
`MATCHNO` ,
`TEAMNO` ,
`PLAYERNO` ,
`WON` ,
`LOST`
)
VALUES (
'0', 'gg', 'ghh', 'hhh', 'hh'
);

主键字段的值插入的值是0.结果看到,保存的并不是0,而变成了1。也正好说明了sql模式"NO_AUTO_VALUE_ON_ZERO"起作用

了。不允许自动增量的值为0(手册:MySQL遇到0值一般会生成新的序列号).经过进一步插入数据测试,注意理解这里的新序

列号:是生成新的序列号。遇到0,假如原来表中已经有个序列号是3,那么就会生成4.接着原来序列号的自增。


结束//////////////////////////////////////////////////////

 

知识收集:

默认sql模式是为空的。非严格模式,难怪我们平时,插入一个字段,数据超过字段,不会报错,会自动截断存储。

使用严格模式(STRICT_TRANS_TABLES),插入的数据超过字段长度,比如常见的char字段类型,会报错,ERROR 1406 (22001): Data too long for column 'testchar' at row 1。

 

还有日期类型的字段。如果设置的值超过日期大小,也不会报错。

 

经验:mysql之所以默认设置为空。非严格模式,也是有道理的。这样容错性强。给一个设置级别给大家,也是可以方便自己根据需要来调试,一般是不太会使用严格模式的,严格模式造成程序很难跑起来,遇到点超过字段长度的错误,都会影响运行。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
2月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
2月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
2月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
349 11
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
|
11月前
|
SQL 存储 关系型数据库
MySQL进阶突击系列(01)一条简单SQL搞懂MySQL架构原理 | 含实用命令参数集
本文从MySQL的架构原理出发,详细介绍其SQL查询的全过程,涵盖客户端发起SQL查询、服务端SQL接口、解析器、优化器、存储引擎及日志数据等内容。同时提供了MySQL常用的管理命令参数集,帮助读者深入了解MySQL的技术细节和优化方法。
|
SQL 存储 关系型数据库
MySQL下使用SQL命令进行表结构与数据复制实践
MySQL下使用SQL命令进行表结构与数据复制实践
272 0
|
SQL 关系型数据库 MySQL
MySQl数据库第八课-------SQL命令查询-------主要命脉2
MySQl数据库第八课-------SQL命令查询-------主要命脉
213 0
|
SQL 关系型数据库 MySQL
MySQl数据库第八课-------SQL命令查询-------主要命脉 1
MySQl数据库第八课-------SQL命令查询-------主要命脉
215 0
|
SQL 存储 开发框架
MySQl数据库第六课-------SQl命令的延续------快来看看
MySQl数据库第六课-------SQl命令的延续------快来看看
190 0

推荐镜像

更多