日期:2014-05-16 浏览次数:20713 次
? 两张表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]