V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
colorsand
V2EX  ›  问与答

请教一个一个稍微有些复杂的 sql 查询

  •  
  •   colorsand · 2015-06-05 13:15:22 +08:00 · 1661 次点击
    这是一个创建于 3256 天前的主题,其中的信息可能已经有所发展或是发生改变。

    有两张表,文章表(id,标题,内容,发布日期)和评论表(id,文章id,内容,发布日期)。

    需要要查询再5月份发布的文章当中,到今天为止超过15天没有新评论的文章,sql语句怎么写?在thinkphp怎么实现这种关联查询?

    5 条回复    2015-06-06 14:06:27 +08:00
    bin456789
        1
    bin456789  
       2015-06-05 16:14:09 +08:00
    mssql的语句,可以参考下,至于thinkphp那种表达式就不清楚了

    SELECT *
    FROM dbo.Articles
    WHERE AddTime >= '2015-5-1'
    AND AddTime < '2015-6-1'
    AND tId NOT IN ( SELECT tId
    FROM dbo.Comment
    WHERE AddTime > GETDATE() - 15 )
    colorsand
        2
    colorsand  
    OP
       2015-06-05 16:28:40 +08:00
    @bin456789 感谢你的回复,一篇文章可能有多条评论,这个语句能保证AddTime是最后那条评论的时间吗?
    bin456789
        3
    bin456789  
       2015-06-05 16:30:54 +08:00
    @colorsand
    SELECT tId
    FROM dbo.Comment
    WHERE AddTime > GETDATE() - 15
    这个子查询是查出15天内有评论的文章Id,所以不用管是不是最后那条评论
    warden2h
        4
    warden2h  
       2015-06-05 16:34:46 +08:00
    join 和not in 都可以
    colorsand
        5
    colorsand  
    OP
       2015-06-06 14:06:27 +08:00
    @bin456789 不知道是不是性能问题,执行这条语句,数据库直接卡死了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2356 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 11:24 · PVG 19:24 · LAX 04:24 · JFK 07:24
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.