doumao8355 2017-04-04 10:11
浏览 80
已采纳

使用DISTINCT选择值的SQL查询,最后只发布一个值

I have a problem with selecting only one value posted by one user.

SELECT DISTINCT(zprava.id_prijemce),
    uzivatele.jmeno,
    uzivatele.prijmeni,
    zprava.zobrazeno
FROM zprava
INNER JOIN uzivatele
    ON zprava.id_prijemce = uzivatele.id
WHERE id_uzivatele = $id_uzivatele
ORDER BY datum DESC

This is what I get:

id_prijemce | jmeno  | prijmeni | zobrazeno
31          | Michal | Harych   | 0
31          | Michal | Harych   | 1
35          | Karel  | Pepík    | 0

This is what I need to get:

id_prijemce | jmeno  | prijmeni | zobrazeno
31          | Michal | Harych   | 1
35          | Karel  | Pepík    | 0

I need not to get the row with higher value of "zobrazeno", but the latest posted, so it can be also 0.

Thank you for your advice.

  • 写回答

1条回答 默认 最新

  • douyasihefu6214 2017-04-04 10:14
    关注

    Use a subquery to identify the latest record in the zprava table, the join this back to zprava and to uzivatele to obtain the results you want.

    SELECT
        t1.id_prijemce,
        t3.jmeno,
        t3.prijmeni,
        t1.zobrazeno
    FROM zprava t1
    INNER JOIN
    (
        SELECT id_prijemce, MAX(datum) AS max_datum
        FROM zprava
        GROUP BY id_prijemce
    ) t2
        ON t1.id_prijemce = t2.id_prijemce AND
           t1.datum       = t2.max_datum
    INNER JOIN uzivatele t3
        ON t1.id_prijemce = t3.id
    WHERE t1.id_uzivatele = $id_uzivatele
    ORDER BY t1.datum DESC
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?