用mysql做数据库开发用严格模式好还是用非严格模式好?

用mysql做数据库开发用严格模式好还是用非严格模式好?,第1张

MySQL开启了严格模式从一定程序上来讲是对我们代码的一种测试,如果我们的开发环境没有开启严格模式在开发过程中也没有遇到错误,那么在上线或代码移植的时候将有可能出现不兼容的情况,因此在开发过程做最好开启MySQL的严格模式

1.可以通过执行SQL语句来开启,但是只对当前连接有效,下面是SQL语句:

代码如下:

set sql_mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

2.通过修改MySQL的配置文件,在配置文件中查找sql-mode,将此行修改成为:

代码如下:

sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

如果查找不到sql-mode=则在[mysqld]下加入即可,推荐第二种方法,可以一劳永逸。

varchar和char的区别:

1、储存长度的不同

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

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服务,也会永久生效了


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6151963.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-16
下一篇 2023-03-16

发表评论

登录后才能评论

评论列表(0条)

保存