美文网首页
SQL中varchar类型在where中注意事项

SQL中varchar类型在where中注意事项

作者: Winter_Soldier | 来源:发表于2018-07-25 22:52 被阅读0次

事情是这样的,今天在写sql的时候,table中有一个字段是platform,本来的意思是:0安卓,1苹果。
但是由于是测试环境,我在仿造数据的时候将一些数据的platform写成了IOS。

//sql
select * from table where platform=1

这时报了个没有这个字段的错误。改成如下sql后没有异常:

//sql
select * from table where `platform`=1
  • 总结:

mysql虽然为我们提供了一些便利,比如可自动将条件中的数字转换成字符串,或将字符串转换成数字,但这种隐性的转换却给系统的扩展和维护埋下了隐患,尤其是一些手工维护的代码表,本来没有什么特别的规则,就是一个编号,无法预期存储的内容。所以对于number的字段用大于,小于或者等于的判断不会有问题,因为数据库里有约束,肯定是数字,但对于varchar类型的字段用就有问题了,所以虽然有些时间sql语句可以执行,但规范的编写方式可以使程序更健壮。

相关文章

网友评论

      本文标题:SQL中varchar类型在where中注意事项

      本文链接:https://www.haomeiwen.com/subject/qzammftx.html