MYSQL 两个表联合查询 比较绕

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

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

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

非常感谢!

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

8个回答

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

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

u011371270
漆黑天使复活 表一是主表 表一id为主键 表二的id是外键 表二另外有一个自己的主键
3 年多之前 回复

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

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

qq_31221931
qq_31221931 你要确保t1必须id为唯一,t2也id为唯一
3 年多之前 回复

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

试试这个

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

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

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

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!