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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容