char和varchar的区别

1.char和varchar是mysql中的两个相似的列,都可以存储字符和字符串。但是char存储的列的长度是不可变的,varchar存储的列的长度是可变的。

  例如:插入char(5)的列表示这个列占用的存储空间一直是5个字符大小。但是在存储数据是往往不会满足5个字符,可能会比5少,也可能会多。比如我们

  插入“abc”时很显然“abc”是3个字符,此时MySql底层会将“abc”后面追加两个空格字符为“abc  ”

  检索时,MySql会自动帮你做一次trim()操作,去掉最后的空格,然后返回“abc”

       

 

 

 2.当定义列为varchar(2)时,存入比2个字符以上的数据时,会出现两种情况

  ①sql mode为严格模式时,插入2个字符以上的数据就会报错

  ②sql mode为非严格模式时,MySql会自动将超出的字符截取,保留符合的字符

3.开启sql mode的方式

  ①先执行select @@sql_mode,复制查询出来的值并将其中的NO_ZERO_IN_DATE,NO_ZERO_DATE删除,然后执行set sql_mode = '修改后的值'或者

           set session sql_mode='修改后的值';,例如:set session sql_mode='STRICT_TRANS_TABLES';改为严格模式此方法只在当前会话中生效,关闭当前会话就不生效了。

       ②先执行select @@global.sql_mode,复制查询出来的值并将其中的NO_ZERO_IN_DATE,NO_ZERO_DATE删除,然后执行set global sql_mode = '修改后的值'。

    此方法在当前服务中生效,重新MySQL服务后失效

  ③在mysql的安装目录下,或my.cnf文件(windows系统是my.ini文件),新增 sql_mode = ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,

   ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,

     添加my.cnf如下:

     [mysqld] sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER

      然后重启mysql。

     此方法永久生效.当然生产环境上是禁止重启MySQL服务的,所以采用方式二加方式三来解决线上的问题,那么即便是有一天真的重启了MySQL服务,也会永久生效了

posted on 2021-08-10 14:33  爱氏晨曦  阅读(2264)  评论(0编辑  收藏  举报