u011371270
漆黑天使复活
采纳率57.5%
2016-03-04 07:19 浏览 2.3k

MYSQL 两个表联合查询 比较绕

20

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

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

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

非常感谢!

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

8条回答 默认 最新

  • 已采纳
    qq423399099 小灸舞 2016-03-04 07: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的人取出它最新的日期
    图片说明

    点赞 1 评论 复制链接分享
  • qq_31221931 qq_31221931 2016-03-04 07:34

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

    点赞 评论 复制链接分享
  • oyljerry oyljerry 2016-03-04 07:38

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

    点赞 评论 复制链接分享
  • qq_31221931 qq_31221931 2016-03-04 07:38

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

    点赞 评论 复制链接分享
  • u010686163 LDIANYANG 2016-03-04 08:12

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

    点赞 评论 复制链接分享
  • Icshadow Icshadow 2016-03-04 08: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 08: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 Jimbo 2016-03-05 07:29

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

    点赞 评论 复制链接分享

相关推荐