具有介于日期范围之间的SQL

具有介于日期范围之间的SQL,sql,sql-server,subquery,between,having,Sql,Sql Server,Subquery,Between,Having,我试图检索另一个表中特定于用户最小日期和最大日期的特定日期范围之间的记录计数 这是我到目前为止所拥有的,但是它排除了我所知道的至少13条记录。你能告诉我我的逻辑是否有错误吗 提前感谢您的任何意见 SELECT rtam.dbo.wfm_process_instance.user_id AS user_id, MIN(rtam.dbo.wfm_process_instance.LOCAL_USER_START_TIME) AS Min_Date, MAX(r

我试图检索另一个表中特定于用户最小日期和最大日期的特定日期范围之间的记录计数

这是我到目前为止所拥有的,但是它排除了我所知道的至少13条记录。你能告诉我我的逻辑是否有错误吗

提前感谢您的任何意见

SELECT   rtam.dbo.wfm_process_instance.user_id AS user_id,
         MIN(rtam.dbo.wfm_process_instance.LOCAL_USER_START_TIME) AS Min_Date,
         MAX(rtam.dbo.wfm_process_instance.LOCAL_USER_START_TIME) AS Max_Date,
         0 AS IVR_Calls,
         COUNT(*) AS Total_Calls
FROM     rtam.dbo.WFM_PROCESS_INSTANCE
         LEFT OUTER JOIN
         rtam.dbo.WFM_PROCESS_type
         ON rtam.dbo.wfm_process_instance.PROCESS_TYPE_INDX = rtam.dbo.wfm_process_type.INDX
WHERE    rtam.dbo.wfm_process_type.DISPLAY_NAME = 'DTV Inbound2'
         AND EXISTS (SELECT   rtam.dbo.gnr_Tbl_72_type.CTRL_USER_ID,
                              CONVERT (VARCHAR (10), MIN(rtam.dbo.gnr_tbl_72_type.LOCAL_COL_113), 101) AS min_date,
                              CONVERT (VARCHAR (10), MAX(rtam.dbo.gnr_tbl_72_type.local_col_113), 101) AS max_date
                     FROM     rtam.dbo.GNR_TBL_72_TYPE
                     WHERE    rtam.dbo.GNR_TBL_72_TYPE.CTRL_USER_ID = rtam.dbo.wfm_process_instance.USER_ID
                     GROUP BY rtam.dbo.GNR_TBL_72_TYPE.CTRL_USER_ID
                     HAVING   rtam.dbo.wfm_process_instance.LOCAL_USER_START_TIME BETWEEN CONVERT (VARCHAR (10), MIN(rtam.dbo.gnr_tbl_72_type.LOCAL_COL_113), 101) AND CONVERT (VARCHAR (10), MAX(rtam.dbo.gnr_tbl_72_type.LOCAL_COL_113), 101))
GROUP BY rtam.dbo.wfm_process_instance.USER_ID
ORDER BY rtam.dbo.wfm_process_instance.USER_ID;
尝试:

拥有rtam.dbo.wfm\u进程\u实例.LOCAL\u用户\u开始时间
>=转换(日期,最小值(rtam.dbo.gnr\U tbl\U 72\U type.LOCAL\U COL\U 113))
和rtam.dbo.wfm_进程_实例(instance.LOCAL)用户_开始时间(TIME)

您还可以考虑使用别名,这样您就不必在代码中重复冗长且容易出错的引用,例如
rtam.dbo.wfm\u process\u instance

那么,您希望这两者之间到底意味着什么?看起来您出于某种原因正在转换为字符串-这是为了节省时间吗?如果是这样,我打赌第13行是正确的在最后一天丢失的是什么?请阅读,和贝特朗先生一样,甚至可以开始弄清楚是什么让你在现存的子查询中选择日期,不必介意转换它们……你需要考虑在函数中包装一个列会阻止SQL Server使用索引并使查询速度变慢。e@AaronBertrand说,澄清你在这里试图做什么。Aaron-是的,如果你展示样本数据和期望的结果,这就消除了最后一天(试穿),我们可能可以编写一个更高效、可读性更高的查询。否则,请尝试更改HAVING子句,如下所示-该查询仍然不会非常有效,但我认为您的13行将重新出现。您好!是的,这很有效!我今晚回家后将发布两个表中的一些示例数据。谢谢!)
HAVING rtam.dbo.wfm_process_instance.LOCAL_USER_START_TIME 
  >= CONVERT(DATE, MIN(rtam.dbo.gnr_tbl_72_type.LOCAL_COL_113)) 
AND rtam.dbo.wfm_process_instance.LOCAL_USER_START_TIME 
  < DATEADD(DAY, 1, CONVERT(DATE, MAX(rtam.dbo.gnr_tbl_72_type.LOCAL_COL_113))