2 u011371270 u011371270 于 2016.03.04 15:19 提问

MYSQL 两个表联合查询 比较绕

表一
ID 基本信息 详细信息
1 张三 张三
2 李四 李四
3 王五 王五
4 老六 老六
表二
ID 详情 修改日期
1 买了个鸡蛋 20160101
1 住院了 20160102
2 死了 20160101
2 又活了 20160102

我想要的结果是查询出ID为1的最新状态,然后结合表一返回一条结果
ID 基本信息 详细信息 详情 修改日期
1 张三 张三 住院了 20160102

我的原始表中表一是基本信息,表二的信息经常更新的(同时用在历史状态搜索
),我想要一条语言搜出对应ID的最新状态,如果放在一个表里面的话,表一会变得很大

非常感谢!

补充一下
表一是主表 表一id为主键 表二的id是外键 表二另外有一个自己的主键

8个回答

qq423399099
qq423399099   Ds   Rxr 2016.03.04 15:49
已采纳

我的整个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的人取出它最新的日期
图片说明

qq_31221931
qq_31221931   2016.03.04 15:34

两表没关联,你是要以谁为主表呢?

u011371270
u011371270 表一是主表 表一id为主键 表二的id是外键 表二另外有一个自己的主键
接近 2 年之前 回复
oyljerry
oyljerry   Ds   Rxr 2016.03.04 15:38

你需要定义两个表之间的关系,比如有一个公共的字段。

qq_31221931
qq_31221931   2016.03.04 15:38

你直接from t1,t2 where t1.id =? and t2.id=? 这样就行

qq_31221931
qq_31221931 你要确保t1必须id为唯一,t2也id为唯一
接近 2 年之前 回复
u010686163
u010686163   2016.03.04 16:12

着用该是多对多吧?这样的话得加一个中间表!

Icshadow
Icshadow   2016.03.04 16:17

试试这个

select a.*,b.详情,b.修改日期 from 表一 a
LEFT JOIN
(
/* 这样就得到了最新状态的数据 */
select * from 表二 inner join (
SELECT max(修改日期) FROM 表二 group by ID ;
)
) b on a.id = b.id

Icshadow
Icshadow   2016.03.04 16:17

select a.*,b.详情,b.修改日期 from 表一 a
LEFT JOIN
(
/* 这样就得到了最新状态的数据 */
select * from 表二 inner join (
SELECT max(修改日期) FROM 表二 group by ID ;
) on 修改日期 = 修改日期
) b on a.id = b.id

WinsenJiansbomber
WinsenJiansbomber   2016.03.05 15:29

哥哥你的数据就是个笑话,等我笑完再来

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!