首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果存在连接SQL,则标记

如果存在连接SQL,则标记
EN

Stack Overflow用户
提问于 2020-07-21 03:03:08
回答 4查看 203关注 0票数 1

具有相同字段名的两个表:学生表(a)中的>> student.id和记录表(b)中的student.id

如果来自学生表的匹配也在记录表中(join on a.student.id = b.student.id),则说"Yes“,否则说"No”as“student.id”

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2020-07-21 03:05:31

如果没有重复项,则可以使用left join

代码语言:javascript
复制
select s.*, (case when r.student_id is null then 'No' else 'Yes' end)
from students s left join
     records r
     on r.student_id = s.id;

如果可能存在重复项,则在加入之前删除重复项:

代码语言:javascript
复制
select s.*, (case when r.student_id is null then 'No' else 'Yes' end)
from students s left join
     (select distinct r.student_id
      from records r
     ) r
     on r.student_id = s.id;
票数 1
EN

Stack Overflow用户

发布于 2020-07-21 03:08:05

考虑一个左连接,它将显示第一个表中的所有记录,以及第二个表中的任何匹配记录。您可以使用CASE语句来显示它们是否匹配。

代码语言:javascript
复制
SELECT
    A.StudentID,
    B.StudentID,
    CASE WHEN b.StudentID IS NOT NULL THEN 'Yes' ELSE 'NO' END As Match
FROM
    StudentA a
    LEFT JOIN StudentB b on a.StudentID = b.StudentID
票数 0
EN

Stack Overflow用户

发布于 2020-07-21 03:09:15

在以下情况下,您可以使用左连接和case

代码语言:javascript
复制
select  case when b.student_id is null then 'No' else 'Yes' END match
from  student a
left join  record  b on a.student_id = b.student_id
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63002200

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档