如何从三个表中获取特定记录

Posted

技术标签:

【中文标题】如何从三个表中获取特定记录【英文标题】:How to fetch a particular record from three tables 【发布时间】:2011-01-06 18:00:26 【问题描述】:

表名 :: Feedback_master

字段 1. feed_id 2. roll_id 3. batch_id 4. sem_id(学期 ID) 5.f_id(教师 ID) 6. sub_id(主题 ID) 7. 备注。 8. b_id

表名 :: subject_master

字段

    sub_id(主题 ID) sub_name(主题名称0 f_id(教师 ID)

表名::faculty_master

字段

    f_id(教师编号) f_name(系名) l_name(系名) b_id

这是三张桌子。现在我想从这三个表中获取详细信息。

我希望输出为

f_Name (faculty name), Sub_name (Subject Name) , and remark (Remark ) when I give (faculty id) f_id

谁能帮我解决这个问题。

【问题讨论】:

【参考方案1】:

使用对象

Select T1.f_name, T2.sub_name, T3.remark from faculty_master as T1, 
subject_master as T2, Feedback_master as T3 where T1.f_id = 'your faculty_id'
and T1.f_id = T3.f_id and T2.sub_id = T3.sub_id

【讨论】:

【参考方案2】:

嘿嘿,我猜是 mysql 吧?

SELECT f_name, sub_name, remark 
FROM faculty_master
LEFT JOIN subject_master USING(f_id)
LEFT JOIN Feedback_master USING(f_id)
WHERE f_id = the_id_you_want

【讨论】:

【参考方案3】:

select fm.f_name, sm.sub_name, remark from Faculty_master fm left 在 fm.f_id=sm.f_id 上加入 sub_master sm 离开加入 feedback_master fbm on sm.sub_id = fbm.sub_id 其中 fm.f_id= 123

【讨论】:

【参考方案4】:

您可以分阶段构建查询。第一件事是你在关注一个反馈评论列表,所以从这个简单的select query开始:

SELECT * FROM Feedback_master

上面列出了来自各地的所有反馈,但您想将其限制为仅针对特定教师的反馈,所以让我们添加一个Where clause:

SELECT * FROM Feedback_master
  WHERE Feedback_master.f_id = @f_id

现在我们得到了正确的记录列表,但是字段列表是错误的。您需要在 Feedback_master 表中没有的教师姓名和学科名称; subject_master 和faculty_master 表是链接在一起的,假设每个remark 都有一个subject ID 和一个faculty ID,我们可以使用一个简单的inner join 来链接表:

SELECT * FROM Feedback_master
  INNER JOIN subject_master ON Feedback_master.sub_id = subject_master.sub_id
  INNER JOIN faculty_master ON Feedback_master.f_id = faculty_master.f_id
  WHERE Feedback_master.f_id = @f_id

现在它从三个表中提取所有字段;这包括我们需要的所有字段,所以我们现在可以在 Select 子句中简单地命名它们:

SELECT
  faculty_master.f_name, subject_master.sub_name, Feeback_master.remark
FROM Feedback_master
  INNER JOIN subject_master ON Feedback_master.sub_id = subject_master.sub_id
  INNER JOIN faculty_master ON Feedback_master.f_id = faculty_master.f_id
WHERE Feedback_master.f_id = @f_id

【讨论】:

以上是关于如何从三个表中获取特定记录的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Swift 从 CoreData sqlite 表中获取特定的行数据

Laravel 如何从“文章”表中获取没有类别的所有记录?

DB2 和 SQL-如何在特定字段中返回最大值,以便每行只显示一条记录;从多个表中提取数据

如何使用 SQL 选择的结果来获取另一个表中的记录?

如何使用 DB2 sql 检查不在两个表中的记录以获取另一个第三个表中的日期?

从具有三个外键的表中选择一个表[关闭]