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的设置, 这种模式下 , 可以获得通用的建表脚本.              
上一篇:nmap加载nse脚本在内网渗透中的使用-上


下一篇:SSD1306指令集