读书人

mysql联表查询联系关系的两个字段类型

发布时间: 2012-07-02 17:46:22 作者: rapoo

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]

读书人网 >Mysql

热点推荐