事情是这样的,今天在写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语句可以执行,但规范的编写方式可以使程序更健壮。
网友评论