Sql查询inner join on 后面的等于号两边数据类型不一致 需要使用cast 或者 convert进行类型强转换

举个简单的实例  分别创建三张表 分别是用户基本信息表 教师扩展信息表  学生扩展信息表  见表语句如下  用户基本信息表中的user_type 的字段相当于外键 如果用户信息代表的是学生 则是学生Id  如果用户基本信息代表的是老师  则表示的教师Id ,教师信息表中的Id是自增类型的  学生信息表中的id是字符串类型用UUID生成(这里只是举这么个例子 不喜勿喷 实际运用中不这么做) 以下分别是三张表的建表语句

用户信息表:

 用户基本信息插入:

学生信息拓展表

教师信息表:

教师表插入信息如下 

 

当我们查教师信息的时候 用简单的inner join 会出现致命的错误 具体情况如下

当我们查询教师信息的时候 需要进行如下类型的转换  cast(t.id as char) 或者 convert(t.id, char) 而不能直接inner join

 以下争对这个业务的三个 sql 第一种是错误的 只有后面两种才是正确的

总结一下 当我们在实际开发中遇到这种类型不一致的进行关联的时候 一定要记得做强类型转换  否则都不知道会发生什么 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值