zoukankan      html  css  js  c++  java
  • 16 SQL Mode

    1.SQL Mode解决的问题:
        a.通过设置SQL Mode , 可以完成不同严格程度的数据校验,有效地保障数据准确性.
        b.通过设置SQL Mode 为ANSI模式,来保证大多数SQL符合标准的SQL语法,应用在不同数据库之间迁移时,对业务SQL进行的修改较小.
        
     
    2.MySQL SQL Mode
        
        MySQL5.0上,默认SQL Mode(参数)为: REAL_AS_FLOAT , PIPES_AS_CONCAT, ANSI_QUOTES , GNORE_SPACE , ANSI .
        这种模式下,允许插入超过字段长度的值,只是在插入后,MySQL会返回一个Warning.
        通过修改SQL Mode 为 STRICT_TRANS_TABLES(严格模式),进行严格的数据校验,使得错误数据不能插入表中,从而保证数据的准确性.
     
        1).查看SQL Mode 命令
            SELECT @@sql_mode ;
     
        2).设置SQL Mode
            SET [SESSION|GLOBAL] sql_mode = 'xx_mode' ;
            
            其中,SESSION :  只在本次连接中生效;
            GLOBAL : 表示本次连接不生效,而对于新的连接则生效.
     
            另外可以在MySQL启动时,通过 --sql-mode="xx_mode" 来设置SQL Mode ;
     
     
    3.SQL Mode 常见功能
        
        1).校验日期的合法性
            严格模式下 , 如果不合法,则报错;例如4月没有31日,这样的数据无法插入.
            非严格模式下, 会插入一条 0000-00-00 00:00:00 的数据
     
        2).INSERT/UPDATE过程中
            严格模式下 MOD(x,0) 这种会报错;
            非严格模式下 会插入 null
     
        3).NO_BACKSLASH_ESCAPES 模式
            导入数据时,如果数据中含有反斜线字符,启用NO_BACKSLASH_ESCAPES模式来保证数据的正确性,是个不错的选择.
        
        4).PIPES_AS_CONCAT模式
            其他数据库,如Oracle使用 || 作为字符串连接符,这样的SQL正常情况下在 MySQL中无法执行, 为了解决这个问题 , MySQL 提供了 PIPES_AS_CONCAT 模式.
     
     
     
    4.常用的SQL Mode
        1).ANSI
            等同于 REAL_AS_FLOAT , PIPES_AS_CONCAT , ANSI_QUOTES , IGNORE_SPACE 和ANSI组合模式 , 使语法和行为更符合标准SQL.
     
        2).STRICT_TRANS_TABLES
            严格模式
     
        3)TRADITIONAL
            等同于 STRICT_TRANS_TABLES , STRICT_ALL_TABLES , NO_ZERO_IN_DATE , NO_ZERO_DATE , ERROR_FOR_DIVISION_BY_ZERO , TRADITIONAL , NO_AUTO_CREATE_USER 组合模式 , 所以它也是严格模式.
     
     
     
     
    4.SQL Mode 在数据迁移中的使用
        1) 各种异构数据库在MySQL中的SQL Mode组合
            
            
     
    DB2 PIPES_AS_CONCAT , ANSI_QUOTES , IGNORE_SPACE , NO_KEY_OPTIONS , NO_TABLE_OPTIONS , NO_FIELD_OPTIONS
    MAXDB PIPES_AS_CONCAT , ANSI_QUOTES , IGNORE_SPACE , NO_KEY_OPTIONS , NO_TABLE_OPTIONS , NO_FIELD_OPTIONS , NO_AUTO_CREATE_USER
    MSSQL PIPES_AS_CONCAT , ANSI_QUOTES , IGNORE_SPACE , NO_KEY_OPTIONS , NO_TABLE_OPTIONS , NO_FIELD_OPTIONS
    ORACLE PIPES_AS_CONCAT , ANSI_QUOTES , IGNORE_SPACE , NO_KEY_OPTIONS , NO_TABLE_OPTIONS , NO_FIELD_OPTIONS , NO_AUTO_CREATE_USER
    POSTGRESQL PIPES_AS_CONCAT , ANSI_QUOTES , IGNORE_SPACE , NO_KEY_OPTIONS , NO_TABLE_OPTIONS , NO_FIELD_OPTIONS
     
        NO_TABLE_OPTIONS : 可以去掉建表语句中的 table options, 例如engine的设置, 这种模式下 , 可以获得通用的建表脚本.
     
     
     
     
     
     
     
  • 相关阅读:
    jmeter HTTP请求之content-type
    MyEclipse10中导入的jquery文件报错(出现红叉叉,提示语法错误)
    MyEclipse使用总结——使用MyEclipse打包带源码的jar包
    MyEclipse使用总结——MyEclipse10安装SVN插件
    Java调用K3Cloud的密码加密算法实现登录密码检验
    Sencha Touch 2 实现跨域访问
    K/3Cloud二次开发基于WebDev附加进程调试
    如何把子单据体的数值合计到单据体上
    移动开发规范概述
    使用HttpWebRequest post数据时要注意UrlEncode
  • 原文地址:https://www.cnblogs.com/lmxxlm-123/p/11132421.html
Copyright © 2011-2022 走看看