一个可以处理 sql server 中的 null 或 valued 日期范围的 sql 查询

A single sql query which can handle both null or valued date range in sql server(一个可以处理 sql server 中的 null 或 valued 日期范围的 sql 查询)
本文介绍了一个可以处理 sql server 中的 null 或 valued 日期范围的 sql 查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

使用 SQL Server 2008.我有一个存储过程,它具有开始和结束日期作为日期范围的输入参数.

Using SQL Server 2008. I have a stored proc which has start and end date as input parameters for date range.

正在寻找一个 单一 sql 查询,它在 where 子句中具有开始和结束日期之间的日期,该查询可以处理日期均为空或两者都有值的两种情况.

Looking for a single sql query which has a between start and end date in the where clause which can handle both cases where the dates are either both null or both have values.

我不想使用 IF 语句.

I don't want to use an IF statement.

推荐答案

WITH    limits AS
        (
        SELECT  COALESCE(@startDate, MIN(mydate)) AS startDate, COALESCE(@endDate, MAX(mydate)) AS endDate
        FROM    mytable
        )
SELECT  m.*
FROM    limits
JOIN    mytable m
ON      mydate BETWEEN startDate AND endDate

如果在 mydate 上有索引,这将是最有效的,因为这个条件是 sargable 并且将使用 Index Seek.

This will be most efficient if there is an index on mydate, since this condition is sargable and will use an Index Seek.

如果没有索引,则使用其他人提出的IFNULL结构.

If there is no index, then use IFNULL constructs proposed by others.

这篇关于一个可以处理 sql server 中的 null 或 valued 日期范围的 sql 查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Number of working days between two dates(两个日期之间的工作日数)
How do I use dateadd to get the first day of last year?(如何使用 dateadd 获取去年的第一天?)
SQL- Count occurrences of a specific word within all stored procedures(SQL- 计算所有存储过程中特定单词的出现次数)
SQL query to make a column of numbers a string(使一列数字成为字符串的 SQL 查询)
T-SQL: Best way to replace NULL with most recent non-null value?(T-SQL:用最新的非空值替换 NULL 的最佳方法?)
Count days in date range with set of exclusions which may overlap(使用一组可能重叠的排除项计算日期范围内的天数)