程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程解疑 >> mysql-MYSQL 兩個表聯合查詢 比較繞

mysql-MYSQL 兩個表聯合查詢 比較繞

編輯:編程解疑
MYSQL 兩個表聯合查詢 比較繞

表一
ID 基本信息 詳細信息
1 張三 張三
2 李四 李四
3 王五 王五
4 老六 老六
表二
ID 詳情 修改日期
1 買了個雞蛋 20160101
1 住院了 20160102
2 死了 20160101
2 又活了 20160102

我想要的結果是查詢出ID為1的最新狀態,然後結合表一返回一條結果
ID 基本信息 詳細信息 詳情 修改日期
1 張三 張三 住院了 20160102

我的原始表中表一是基本信息,表二的信息經常更新的(同時用在歷史狀態搜索
),我想要一條語言搜出對應ID的最新狀態,如果放在一個表裡面的話,表一會變得很大

非常感謝!

補充一下
表一是主表 表一id為主鍵 表二的id是外鍵 表二另外有一個自己的主鍵

最佳回答:


我的整個SQL語句是這樣的:
select i.id,i.basic_info,i.detailed_info,s.detailes,s.date from people_info i,people_status s where i.id=s.id and i.id=1 and s.date=(select date from people_status where id=1 order by date desc limit 1);
下面稍微分析一下:
select i.id,i.basic_info,i.detailed_info,s.detailes,s.date from XXX //這個很好理解,搜索顯示i表中的3個字段和s表中的2個字段
from people_info i,people_status s //給兩個表取別名,一個叫i一個叫s
where i.id=s.id and i.id=1 //兩表用id值就行連接,並且id=1
and s.date=(select date from people_status where id=1 order by date desc limit 1);//最後一個條件就是id=1的人取出它最新的日期
圖片說明

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved