MySql Int 类型和 varchar类型进行比较。
2013-06-26 16:18
120 查看
今天遇到个比较奇葩的问题,简单讲就是在Mysql中进行查询的时候 在Where语句中使用的int类型的字段和Varchar类型的字段进行对比。
例如:我这有一张表:
表中的数据如下:
当我进行查询的时候:
奇葩的问题出现了:
按道理讲,234是不等于234dgdgdgdgdgd的,可为什么Mysql会在这里认为他们是相等的?
把ID的类型转换为Varchar以后,该问题就不存在了。
不知道Mysql内部的机制是怎样的,但应该是把234dgdgdgdgdgd开始截取的数字转换成int类型然后进行的比较。
该类型的问题告诉我们必须要注意在数据库中的比较要确保字段的类型一致。
例如:我这有一张表:
表中的数据如下:
当我进行查询的时候:
奇葩的问题出现了:
按道理讲,234是不等于234dgdgdgdgdgd的,可为什么Mysql会在这里认为他们是相等的?
把ID的类型转换为Varchar以后,该问题就不存在了。
不知道Mysql内部的机制是怎样的,但应该是把234dgdgdgdgdgd开始截取的数字转换成int类型然后进行的比较。
该类型的问题告诉我们必须要注意在数据库中的比较要确保字段的类型一致。
相关文章推荐
- mysql datetime 类型的字段进行时间比较
- MySql中的varchar转换成int类型排序
- MySQL及Oracle中将varchar类型转换成int类型
- SQL技术内幕-7 varchar类型的数字和 int 类型的数字的比较+cast的适用
- MySql中的varchar转换成int类型排序
- mysql varchar类型转换int类型
- 关于MySQL数据类型定义的几个细节-INT(N)/VARCHAR(N)/DECIMAL(M,N)
- mysql varchar类型转换int类型
- mysql列类型char,varchar,text,tinytext,mediumtext,longtext的比较与选择
- mysql字段类型范围说明:int、bigint、smallint、tinyint,char、varchar、nvarchar
- mysql的数据类型int、bigint、smallint 和 tinyint取值范围 及varchar
- postgresql 数据支持 jsonb/json中 array或int 类型进行的交集比较
- MySQL中varchar类型转int
- MySql中的varchar转换成int类型排序
- MySql存储日期类型用int、datetime还是varchar?
- mysql字段类型范围说明:int、bigint、smallint、tinyint,char、varchar、nvarchar
- mysql varchar类型转换日期类型,比较大小
- Mysql中int和varchar类型
- MySQL数据类型char、varchar、text的比较
- mysql列类型char,varchar,text,tinytext,mediumtext,longtext的比较与选择