日期:2014-05-16  浏览次数:20713 次

mysql联表查询关联的两个字段类型不一致的解决方案

? 两张表A,B.现在通过A表的REC_ID(INT)和B表的PROD_ID(VARCHAR(50))进行关联查询,类似于以下的查询SQL:

SELECT a.*,b.* FROM A a left join B b on a.rec_id = b.prod_id;由于两个表的两个字段类型不一致,如果大数据量查询的时候,速度会非常慢。通过以下的优化,问题解决;SQL:SELECT a.*,b.* FROM A a left join B b on conver(a.rec_id,char) = b.prod_id。

? 在测试的过程中曾尝试通过char(a.rec_id)、concat(a.rec_id,'')和cast((rec_id as char))等方式均没有成功。

? MYSQL中CAST() 和CONVERT() 函数可用来获取一个类型的值,并产生另一个类型的值。
? 这个类型 可以是以下值其中的 一个:
??? BINARY[(N)]
??? CHAR[(N)]
??? DATE
??? DATETIME
??? DECIMAL
??? SIGNED [INTEGER]
??? TIME
??? UNSIGNED [INTEGER]