mysql两表联合查询,两个表结构一样,多个字段中的3个字段,只要这3个字段有重复的就罗列出来,请大家帮忙
直接点下面这个链接,是我在mysql社区的提问,比较详细http://www.mysqlpub.com/forum.php?mod=viewthread&tid=3099...
直接点下面这个链接,是我在mysql社区的提问,比较详细
http://www.mysqlpub.com/forum.php?mod=viewthread&tid=30993#lastpost
大家帮忙看看怎么实现呢?
http://www.oschina.net/question/272636_49426
这么说吧,一辆 车牌为 吉B3120 挂的车 在2011年3月1日上了险种为DAA,DZA两种险,截止到2012年3月1日,当时还不知道发动机号或者车大架号,也可能还为上牌,但是车牌,发动机号,大架号肯定有一项是填了的
到2012年3月1日又开始续保,还是DAA,DZA两种险,这回有大架号了,就把大架号填上了。
我要查询的就是2011年3月1日上险了 到2012年3月1日看看续保没有 不知道我说的清楚没
a表是2011年3月1日
b表是2012年3月1日 展开
http://www.mysqlpub.com/forum.php?mod=viewthread&tid=30993#lastpost
大家帮忙看看怎么实现呢?
http://www.oschina.net/question/272636_49426
这么说吧,一辆 车牌为 吉B3120 挂的车 在2011年3月1日上了险种为DAA,DZA两种险,截止到2012年3月1日,当时还不知道发动机号或者车大架号,也可能还为上牌,但是车牌,发动机号,大架号肯定有一项是填了的
到2012年3月1日又开始续保,还是DAA,DZA两种险,这回有大架号了,就把大架号填上了。
我要查询的就是2011年3月1日上险了 到2012年3月1日看看续保没有 不知道我说的清楚没
a表是2011年3月1日
b表是2012年3月1日 展开
3个回答
展开全部
你是要以哪个表的数据为基准呢?
如果是以A表的数据为基准,则SQL可以用下面的:
select a.xianzhong, a.chepai, a.fadongji, a.chejiahao
from a left join b on a.xianzhong = b.xianzhong and (a.chepai = b.chepai or a.fadongji = b.fadongji or a.chejiahao = b.chejiahao)
如果是以B表为基准,则SQL如下:
select b.xianzhong, b.chepai, b.fadongji, b.chejiahao
from a right join b on a.xianzhong = b.xianzhong and (a.chepai = b.chepai or a.fadongji = b.fadongji or a.chejiahao = b.chejiahao)
如果是以A表的数据为基准,则SQL可以用下面的:
select a.xianzhong, a.chepai, a.fadongji, a.chejiahao
from a left join b on a.xianzhong = b.xianzhong and (a.chepai = b.chepai or a.fadongji = b.fadongji or a.chejiahao = b.chejiahao)
如果是以B表为基准,则SQL如下:
select b.xianzhong, b.chepai, b.fadongji, b.chejiahao
from a right join b on a.xianzhong = b.xianzhong and (a.chepai = b.chepai or a.fadongji = b.fadongji or a.chejiahao = b.chejiahao)
追问
你写的不对,如果以b表为基准,按你的查询是如下结果:
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
SELECT * FROM a a,b b
WHERE a.chepai=b.chepai OR a.chepai=b.chepai OR a.fadongji=b.fadongji OR a.chejiahao=b.chejiahao
on a.xianzhong=b.xianzhong
试试吧,有问题再追问
WHERE a.chepai=b.chepai OR a.chepai=b.chepai OR a.fadongji=b.fadongji OR a.chejiahao=b.chejiahao
on a.xianzhong=b.xianzhong
试试吧,有问题再追问
更多追问追答
追问
不对
我的是mysql
你的写法不对 而且你这么写根本不是我要的结果
追答
这还不对?哥在oracle下都试了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select b.* from a left join b on a.xianzhong=b.xianzhong where ((case when a.chepai=b.chepai then 1 else 0 end)+(case when a.fadongji=b.fadongji then 1 else 0 end)+(case when a.chejiahao=b.chejiahao then 1 else 0 end))>1
更多追问追答
追问
你的这个写法 不错 好像已经实现了 我再测试下 先谢谢你了
追答
我测试过无误
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询