首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >SQL查询中的IF条件

SQL查询中的IF条件
EN

Stack Overflow用户
提问于 2012-04-20 06:52:03
回答 8查看 72.7K关注 0票数 10

我是SQL Server的新手。请帮助我在查询中写下下面的逻辑。

代码语言:javascript
运行
复制
If getnow() > today 4 PM
Then
    SELECT *
    FROM table
    WHERE MailDate is Tomorrow
Else
    SELECT *
    FROM table
    WHERE MailDate is Today
EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2012-04-20 07:02:23

代码语言:javascript
运行
复制
select *
from table
where DATEDIFF(day, GETDATE(), maildate) = case when
    DATEPART(hour, GETDATE()) >= 16 then 1 else 0
end
票数 8
EN

Stack Overflow用户

发布于 2012-04-20 07:01:53

代码语言:javascript
运行
复制
IF datepart(hh, getdate()) >= 16
    BEGIN
        SELECT *
        FROM table
        WHERE DateDiff(day, getdate(), MailDate) = 1
    END
ELSE
    BEGIN
        SELECT *
        FROM table
        WHERE DateDiff(day, getdate(), MailDate) = 0
    END
票数 3
EN

Stack Overflow用户

发布于 2012-04-20 07:49:43

我不知道确切的MS-语法-方言,但我将尝试证明您不需要IF或CASE构造。我以@mellamokb的回复为例。

代码语言:javascript
运行
复制
SELECT *
  FROM the_table
 WHERE ( DATEPART(hour, GETDATE()) >= 16
           AND DATEDIFF(day, GETDATE(), MailDate) = 1)
    OR (DATEPART(hour, GETDATE()) < 16
           AND DATEDIFF(day, GETDATE(), MailDate) = 0)
     ;   
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10237984

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档