Join table depending on value of column in main table(根据主表中列的值连接表)
本文介绍了根据主表中列的值连接表的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
notificationTable
ID type typeID userID
==============================================
1 comment 34 2
2 accept 22 2
eventTable
ID event content
===================================
21 post 34
22 accept 22
commentTable
ID comment eventID
===================================
34 'test' 21
我想根据列类型的值连接不同的表.这是我当前的伪代码:
I want to join different tables depending on the value of the column type. This is my current pseudocode:
SELECT *
FROM notificationTable notification
IF (notification.type == 'comment')
LEFT JOIN commentTable comment
ON notification.typeID = comment.ID
ELSEIF (notification.type == 'accept')
LEFT JOIN evenTable event
ON notification.typeID = event.ID
WHERE notification.userID = 2
有人知道我的意图的真正查询吗?
Anyone knows the real query for my intention?
推荐答案
类似
SELECT *
FROM notificationTable notification
LEFT JOIN commentTable comment
ON (notification.typeID = comment.ID AND notification.type == 'comment')
LEFT JOIN evenTable event
ON (notification.typeID = event.ID AND notification.type == 'accept')
WHERE notification.userID = 2
但我强烈建议重新设计你的系统以避免多态关系...
But I strongly recommend to redesign your system to avoid polymorphic relationship...
这篇关于根据主表中列的值连接表的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
编程基础网
本文标题为:根据主表中列的值连接表
基础教程推荐
猜你喜欢
- SQL Server 实例在登录协商期间返回无效或不受支持的协议版本 2021-01-01
- 如何使用 mysql.connector 禁用查询缓存 2022-01-01
- 是否可以执行按位分组功能? 2021-01-01
- SQL:使用来自具有相同列名的两个表中的数据... 2021-01-01
- 在 SQL 中连接多个表 2021-01-01
- SQL 效率:WHERE IN 子查询 vs. JOIN 然后 GROUP 2021-01-01
- SSMS 中的权限问题:“对象 'extended_properties'、数据库 'mssqlsystem_resource'、... 错误 229)上的 SELECT 权限被拒绝" 2022-01-01
- 需要 MySQL 5.1 中的抽象触发器来更新审计日志 2021-01-01
- 无法解决整理冲突 2021-01-01
- 将 SQL Server DateTime 列迁移到 DateTimeOffset 2021-01-01
