sql 两个表联合查询

xyq0125 2011-12-22 10:14:53

select a.Id,a.RName,c.Formula,c.Mscore,c.Wscore,c.Number from Rules as a,JLScore as c
where a.Flag='1' and a.Rid='1' and c.Jid='2' and c.JType =a.Id

select Id,RName from Rules where Rid='1'


上面两条sql查询得到的结果为:
id RName Formula Mscore Wscore Number
1 细则1 (完成值-目标值)*基数 200 210 3

Id RName
1 细则1
2 细则2

问:我要如何写sql语句能将两个接口合并?
效果:
Id RName Formula Mscore Wscore Number
1 细则1 (完成值-目标值)*基数 200 210 3
2 细则2 null null null null
...全文
104 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
JayPan2008 2011-12-22
  • 打赏
  • 举报
回复
SELECT a.Id,a.RName,c.Formula,c.Mscore,c.Wscore,c.Number FROM @Rules AS a
LEFT JOIN @JLScore as c
ON c.JType =a.Id AND a.Flag='1' and a.Rid='1' and c.Jid='2'
yesterday5100 2011-12-22
  • 打赏
  • 举报
回复
select a.Id,a.RName,c.Formula,c.Mscore,c.Wscore,c.Number from Rules as a,JLScore as c
where a.Flag='1' and a.Rid='1' and c.Jid='2' and c.JType =a.Id
union
select Id,RName from Rules where Rid='1'
风2013 2011-12-22
  • 打赏
  • 举报
回复
用 left join 链接两条语句的结果集



select c.* ,b.* from (select Id,RName from Rules where Rid='1') c
left join

(select a.Id,a.RName,c.Formula,c.Mscore,c.Wscore,c.Number from Rules as a,JLScore as c
where a.Flag='1' and a.Rid='1' and c.Jid='2' and c.JType =a.Id) d on c.id=d.id

油泼白菜 2011-12-22
  • 打赏
  • 举报
回复
LEFT JOIN 返回左表中所有的行
xyq0125 2011-12-22
  • 打赏
  • 举报
回复
1楼解决问题。
2楼方法报错啊。
3楼接口不是我想要的。

62,073

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧