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

mysql非严格模式设置

基础概念

MySQL的非严格模式(Non-Strict Mode)是指MySQL在执行SQL语句时,对于某些不符合严格数据完整性的行为采取宽松的处理方式。在非严格模式下,MySQL可能会允许插入或更新一些在严格模式下会被拒绝的数据。

相关优势

  1. 灵活性:非严格模式提供了更大的灵活性,允许在某些情况下插入或更新不完全符合规范的数据。
  2. 兼容性:对于一些旧的应用程序或数据源,非严格模式可以更好地兼容,减少数据迁移和转换的难度。

类型

MySQL的非严格模式主要体现在以下几个方面:

  1. STRICT_TRANS_TABLES:在这种模式下,MySQL会对事务表(如InnoDB表)执行严格的SQL模式检查。
  2. STRICT_ALL_TABLES:在这种模式下,MySQL会对所有表执行严格的SQL模式检查。
  3. NO_ZERO_DATE:在这种模式下,MySQL不允许插入或更新包含零日期(如'0000-00-00')的记录。
  4. NO_ZERO_IN_DATE:在这种模式下,MySQL不允许插入或更新包含无效日期(如'2020-02-30')的记录。

应用场景

非严格模式通常用于以下场景:

  1. 数据迁移:在从旧系统迁移到新系统时,可能会遇到一些不符合严格数据规范的数据,非严格模式可以容忍这些数据。
  2. 旧应用程序:一些旧的应用程序可能没有严格的数据验证逻辑,使用非严格模式可以避免这些应用程序在迁移过程中出现问题。

遇到的问题及解决方法

问题:为什么在非严格模式下插入无效日期会成功?

原因:在非严格模式下,MySQL允许插入或更新一些在严格模式下会被拒绝的数据,例如无效日期。

解决方法:可以通过修改SQL模式来启用严格模式,从而避免插入无效数据。例如:

代码语言:txt
复制
SET GLOBAL sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_DATE,NO_ZERO_IN_DATE';

问题:如何在非严格模式下处理零日期?

原因:在非严格模式下,MySQL允许插入或更新包含零日期的记录。

解决方法:可以通过设置NO_ZERO_DATE模式来禁止插入或更新零日期。例如:

代码语言:txt
复制
SET GLOBAL sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_DATE';

示例代码

以下是一个示例代码,展示如何在MySQL中设置非严格模式:

代码语言:txt
复制
-- 查看当前的SQL模式
SHOW VARIABLES LIKE 'sql_mode';

-- 设置非严格模式
SET GLOBAL sql_mode = 'ALLOW_INVALID_DATES';

-- 插入无效日期(在非严格模式下会成功)
INSERT INTO my_table (date_column) VALUES ('2020-02-30');

-- 切换回严格模式
SET GLOBAL sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_DATE,NO_ZERO_IN_DATE';

参考链接

MySQL SQL Mode

通过以上信息,您可以更好地理解MySQL的非严格模式及其相关应用场景和解决方法。

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

相关·内容

国产数据库兼容过程中涉及的MySQL非严格模式

在国产数据库兼容适配过程中,经常遇到因源数据库是MySQL,迁移至其他国产数据库后,因MySQL端兼容模式有非严格模式,导致适配过程过程中需要做调整。...那么,MySQL主要的非严格模式小结如下: 1、非严格模式参数 MySQL的非严格模式指的是在MySQL配置中禁用严格模式(Strict Mode)的情况下执行的SQL。...简单举例 以下是一些非严格模式下可能出现的案例情况: 1) 非严格的日期和时间插入:在非严格模式下,MySQL允许插入不符合日期和时间格式的值,会自动进行转换或舍入 eg: 不合法的日期值'0000...可以插入150,且插入后的值自动截断为 127 4) 非严格的零值插入:在非严格模式下,MySQL允许插入字符串类型的值到数值类型字段,会将非数值字符串转换为0 (建议已开启此类严格模式) eg:...eg: 10/0 ,结果为null 9) 非严格的字符串引号标识:在非严格模式下,MySQL允许单引号及双引号来引用字符串 eg: 'abc' 或 "abc"均可 10)非严格的grant模式自动创建用户

36120
  • 严格模式

    JS的严格模式采用具有限制性javascript变体的一种方式,即在严格的条件下运行js代码。 严格模式对正常模式做了如下更改 消除了js语法的不合理、不严谨之处、减少了一些怪异行为。...如正常模式变量不声明可以直接赋值 消除代码运行的一些不安全之处,保证代码运行安全。...提高编译器效率,增加运行速度 禁用了未来版本的一些语法如class、export、extends、import不能作为变量名 开启严格模式 严格模式可在整个脚本,或者某个函数开启 脚本严格模式 代码最前面..."use strict" //或者 (function(){ "use strict" }) 函数严格模式 function test(){ "use strict" } 主要变化 变量必须声明在赋值...严禁删除已经声明的变量 如delete 变量 严格模式下全局作用域中的函数中的this是undefined new实例化的构造函数指向创建对象的实例 定时器this还是指向window 函数里面的参数不允许重名

    48920

    JavaScript 严格模式

    (JavaScript高级程序设计) 设立严格模式的目的: 严格模式会将JavaScript陷阱直接变成明显的错误。 严格模式修正了一些引擎难以优化的错误。...同样的代码有些时候严格模式会比非严格模式下更快。 严格模式禁用了一些有可能在未来版本中定义的语法。 开启严格模式 使用 ‘use strict’; 进入严格模式。...为整个script标签开启严格模式 // 整个语句都开启严格模式的语法 "use strict"; console.log('严格模式script') 注意: 如果要为整个script开启严格模式,‘use...函数声明 严格模式只允许在全局作用域或函数作用域的顶层声明函数。也就是说,不允许在非函数的代码块内声明函数。...参考链接 MDN严格模式 Javascript 严格模式详解

    82930

    JavaScript严格模式

    use strict" 的目的是指定代码在严格条件下执行。严格模式下你不能使用未声明的变量。 严格模式声明 严格模式通过在脚本或函数的头部添加 "use strict"; 表达式来声明。...实例 严格模式使用标志,将"use strict"放在脚本文件的第一行,则整个脚本都将以"严格模式"运行。如果这行语句不在第一行,则无效,整个脚本以"正常模式"运行。..."use strict"; 严格模式调用有两种方式,       "use strict";     console.log("这是严格模式。")...严格模式创设了第三种作用域:eval作用域。 正常模式下,eval语句的作用域,取决于它处于全局作用域,还是处于函数作用域。...为了与新版本接轨,严格模式只允许在全局作用域或函数作用域的顶层声明函数。也就是说,不允许在非函数的代码块内声明函数。

    1.4K50

    JavaScript 严格模式

    严格模式对正常的 JavaScript 语义做了一些更改: 严格模式通过抛出错误来消除了一些原有静默错误; 严格模式修复了一些导致 JavaScript引擎难以执行优化的缺陷:有时候,相同的代码,严格模式可以比非严格模式下运行得更快...当打包文件时(多个文件打包成一个),你最好将所有的文件(打包之前的)都设置成严格模式或非严格模式,因为如果不这样做,打包后的文件可能并不是严格模式,可能会背离你的目的。...而如果是非严格模式,除了最后 obj 的那一个,其余都返回 false。这是因为非严格模式下,this 会被包装成一个对象。...例如 Object.defineProperty 方法可以给对象的键设置一些属性,比如设置不可写属性: var obj1 = {}; Object.defineProperty(obj1, "x", {...这种表示八进制(普通模式下表示八进制),可以使用 0o21 表示八进制; 严格模式下禁止给基本类型设置属性(string,number,bigint,boolean,null,undefined,symbol

    97610

    23严格模式

    不支持严格模式的刘览器与支持严格模式的浏览器行为上也不一样,所以不要在未经严格模式特性测试情况下使用严格模式。 严格模式可以与非严格模式共存,所以脚本可以逐渐的选择性加入严格模式。...其次,严格模式修正了一些引擎难以优化的错误:同样的代码有些时候严格模式会比非严格模式下更快 第三,严格模式禁用了一些有可能在未来版本中定义的语法。...= "张无忌"; console.log(obj); 以上代码在严格模式下会报错,非严格模式下不会报错。...非严格模式下为周芷若 } fn("周芷若"); 非严格模式下arguments对象获取参数的值与形参有关。...eval("var v = 100"); console.log(v); 以上代码在非严格模式下会输出100,而在严格模式下会抛出错误。 在严格模式下,会增加eval作用域。

    79730

    严格模式 – JavaScript

    不支持严格模式的浏览器与支持严格模式的浏览器行为上也不一样, 所以不要在未经严格模式特性测试情况下使用严格模式。严格模式可以与非严格模式共存,所以脚本可以逐渐的选择性加入严格模式。...其次,严格模式修正了一些引擎难以优化的错误:同样的代码有些时候严格模式会比非严格模式下更快。 第三,严格模式禁用了一些有可能在未来版本中定义的语法。...试想合并一个严格模式的脚本和一个非严格模式的脚本:合并后的脚本代码看起来是严格模式。反之亦然:非严格合并严格看起来是非严格的。...合并均为严格模式的脚本或均为非严格模式的都没问题,只有在合并严格模式与非严格模式有可能有问题。建议按一个个函数去开启严格模式(至少在学习的过渡期要这样做)....语法错误 197 + 142; 第七,ECMAScript 6中的严格模式禁止设置primitive值的属性.不采用严格模式,设置属性将会简单忽略(no-op

    1K30

    使用 TypeScript“严格”模式进行类型严格编码

    一些背景信息,我在 C 和 C++ 方面有丰富的经验,这些语言通常是类型严格的。但是,当考虑到我花费大量时间开发网站等项目时,我从未真正使用过 TypeScript 或其严格模式。...工作流程幸运的是,这个问题本身给了我一个直接链接到严格模式文档的链接。我浏览了一下,过了一遍启用和维护严格模式代码库的一些检查和要求,然后很快就开始工作了。...我浏览了包含 Blockly 插件的文件夹,并直接进入了其 tsconfig.json 文件以启用严格模式,非常简单。...这样做之后,我运行了 npm run build,显示了许多由于严格模式类型检查而需要修复的错误。...每当代码需要 minimapWrapper 有一个值时,严格模式就会对我们大声呼喊,除非我们包含这个简单的检查:if(!

    25710

    严格模式use strict

    而早在ES5就提出了第二种运行模式严格模式,就是希望开发者能慢慢的脱离马虎模式/稀松模式/懒散模式(sloppy)模式。...严格模式IE10以上和各大浏览器都已经支持,要注意的是,相同代码在严格模式和非严格模式下运行得到的结果会有不同。主要还是增加了很多静默是吧抛出异常。...禁止了八进制表示法 ECMAScript 6中的严格模式禁止设置primitive值的属性.不采用严格模式,设置属性将会简单忽略(no-op),采用严格模式,将抛出TypeError错误。...在严格模式下 eval 仅仅为被运行的代码创建变量, 所以 eval 不会使得名称映射到外部变量或者其他局部变量。 无法删除变量。只有configurable设置为true的对象属性,才能被删除。...10,非严格模式输出20。

    95920
    领券