表一
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的人取出它最新的日期
两表没关联,你是要以谁为主表呢?
你需要定义两个表之间的关系,比如有一个公共的字段。
你直接from t1,t2 where t1.id =? and t2.id=? 这样就行
着用该是多对多吧?这样的话得加一个中间表!
试试这个
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
哥哥你的数据就是个笑话,等我笑完再来