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



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

  • 相关阅读:
    并发与多线程
    java多线程--死锁
    java变量
    StringStringBufferStringBuilder区别
    java8新特性
    spring自动装配和通过java实现装配
    CSP -- 运营商内容劫持(广告)的终结者
    【Composer】实战操作二:自己创建composer包并提交
    【个人重点】开发中应该重视的几点
    【Composer】实战操作一:使用库
  • 原文地址:https://www.cnblogs.com/wangtao_20/p/1961795.html
Copyright © 2020-2023  润新知