- 起因:
事情是这样的,今天在写sql的时候,table中有一个字段是platform,本来的意思是:0安卓,1苹果。但是由于是测试环境,我在仿造数据的时候将一些数据的platform写成了IOS。 - SQL:
select * from table where platform=1这时报了个没有这个字段的错误。改成如下sql后没有异常:
select * from table where `platform`=1 - 总结:
mysql虽然为我们提供了一些便利,比如可自动将条件中的数字转换成字符串,或将字符串转换成数字,但这种隐性的转换却给系统的扩展和维护埋下了隐患,尤其是一些手工维护的代码表,本来没有什么特别的规则,就是一个编号,无法预期存储的内容。所以对于number的字段用大于,小于或者等于的判断不会有问题,因为数据库里有约束,肯定是数字,但对于varchar类型的字段用就有问题了,所以虽然有些时间sql语句可以执行,但规范的编写方式可以使程序更健壮。
在使用SQL进行数据查询时,字段类型的选择至关重要。本文通过一个实例,讲述了在MySQL中,数字字段与字符串字段在查询时的区别,以及如何避免由字段类型不匹配引起的错误。强调了规范编写SQL语句的重要性,以确保程序的健壮性。
1467

被折叠的 条评论
为什么被折叠?



