在 SQL Server 2008 R2 中创建索引视图和 Group BY 时出现问题
我想使用这样的 t-sql 创建索引视图:
Select
Table1_ID,
cast(CONVERT(varchar(8),
t2.Object_CreationDate, 112)AS DateTime) as Object_CreationDate ,
Count_BIG(*) as ObjectTotalCount
from
[dbo].Table2 t2 inner join [dbo].Table1 t1 on ...
Group BY
Table1_ID, CONVERT(varchar(8), t2.Object_CreationDate, 112))
我需要仅按列 Object_CreationDate
的 datepart (类型 日期时间2)。
另外,我想在派生视图中的列 Theme_Id
和 Object_CreationDate
上设置索引。
如果我在 SELECT 中使用 cast(CONVERT(varchar(8), m.Mention_CreationDate, 112)AS DateTime)
- 我会遇到此列上的索引问题。因为此列 (Object_CreationDate
) 不是确定性的。
我想知道是否可以解决问题。
I want to create indexed view with such t-sql:
Select
Table1_ID,
cast(CONVERT(varchar(8),
t2.Object_CreationDate, 112)AS DateTime) as Object_CreationDate ,
Count_BIG(*) as ObjectTotalCount
from
[dbo].Table2 t2 inner join [dbo].Table1 t1 on ...
Group BY
Table1_ID, CONVERT(varchar(8), t2.Object_CreationDate, 112))
I need to make group by only by datepart of column Object_CreationDate
(type datetime2 ).
Also I want to set index on columns Theme_Id
AND Object_CreationDate
in the derived view.
If I use cast(CONVERT(varchar(8), m.Mention_CreationDate, 112)AS DateTime)
in SELECT - I'll get problems with index on this column. Because this column (Object_CreationDate
) is not deterministic.
I wonder if it is possible to solve a problem.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
将 ... ... 替换
为
第二个格式仅适用于 SQL Server 2008+,第一个格式更通用
这将从日期/日期时间数据类型域中的日期时间值中删除时间组件,而无需任何中间区域设置相关的日期时间格式
请参阅以下答案: 一个和两个(评论)
replace ...
... with
The 2nd format is SQL Server 2008+ only, the 1st is more general
This removes the time component from a datetime value in the date/datetime datatype domain without any intermediate locale dependent datetime formats
See these answers: One and Two(comments)