有什么办法可以组合这两个sql删除操作的逻辑?

时间:2019-03-28 13:48:47

标签: mysql sql

我正在用SQL编写两个DELETE操作。第一个删除数据库中设置了学生角色名称的条目。第二个删除一个名称为null的条目。我想知道我是否可以使用一个可以处理两种逻辑的SQL命令,还是需要将它们分开?

我有4个表StudentClassStudent_RoleSignup。下面的删除将删除用户提供学生的唯一ID,班级的唯一ID以及学生角色的名称的条目。

注册有3列(CLASS_ID,STUDENT_ID,STUDENT_ROLE_ID),它们都是外键

1st DELETE command:

DELETE S FROM SIGNUP S
INNER JOIN CLASS ON CLASS.ID = S.CLASS_ID
INNER JOIN STUDENT ON STUDENT.ID = S.STUDENT_ID
INNER JOIN STUDENT_ROLE ON STUDENT_ROLE.ID = SDR.STUDENT_ROLE_ID
WHERE CLASS.UNIQUE_ID = :classUniqueId AND
STUDENT.UNIQUE_ID = :studentUniqueId AND STUDENT_ROLE.NAME = :roleName

但是,如果我为null传递了roleName,则此查询将无法工作。基本上,我的第二个用例是我要删除一条记录,其中学生唯一ID和班级唯一ID与用户提供的内容匹配,但角色名称不存在。在这种情况下,它是null。因此,对于这种情况,我还有另一个DELETE声明:

2nd DELETE command:

DELETE S FROM SIGNUP S
INNER JOIN CLASS ON CLASS.ID = S.CLASS_ID
INNER JOIN STUDENT ON STUDENT.ID = S.STUDENT_ID
WHERE CLASS.UNIQUE_ID = :classUniqueId AND STUDENT.UNIQUE_ID = :studentUniqueId
AND S.STUDENT_ROLE_ID IS NULL

现在,我想知道是否可以将这两个语句组合成一个可以处理任何一种情况的语句(用户提供特定的学生角色ID,或者角色ID为null)。最后,应该只输入一个已删除。有什么办法可以做到这一点?

1 个答案:

答案 0 :(得分:0)

不确定我是否了解您,但是也许这就是您想要的

DELETE S 
FROM   signup S 
       INNER JOIN class 
               ON class.id = S.class_id 
       INNER JOIN student 
               ON student.id = S.student_id 
       LEFT JOIN student_role 
              ON student_role.id = S.student_role_id 
WHERE  class.unique_id = :classUniqueId 
       AND student.unique_id = :studentUniqueId 
       AND ( ( :roleName IS NULL 
               AND S.student_role_id IS NULL ) 
              OR ( :roleName IS NOT NULL 
                   AND student_role.NAME = :roleName ) )

将STUDENT_ROLE从INNER JOIN更改为LEFT JOIN,并在where子句“忽略” STUDENT_ROLE.NAME中检查:roleName是否为NULL。