首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > Mysql >

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

2012-07-02 
mysql联表查询关联的两个字段类型不一致的解决方案? 两张表A,B.现在通过A表的REC_ID(INT)和B表的PROD_ID(V

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]

热点排行