为了账号安全,请及时绑定邮箱和手机立即绑定

SqlDependency的局限性是什么

SqlDependency的局限性是什么

C#
慕姐8265434 2019-12-26 09:48:30
我使用一个表作为消息队列,并使用SqlDependency进行“注册”以进行更新。在我读过的所有地方,人们都在说要注意它的局限性,而不是专门说一下它们是什么。根据我的收集,当表的更新频率很高时,您会遇到问题,幸运的是,我每分钟最多只能查看10-20个值。还有什么其他限制/对SqlServer的影响?
查看完整描述

3 回答

?
MM们

TA贡献1886条经验 获得超2个赞

我可以从这里找到最完整的列表如下:

  • SELECT语句中的投影列必须明确声明,并且表名必须由两部分组成。请注意,这意味着该语句中引用的所有表必须位于同一数据库中。

  • 该语句不能使用星号()或table_name。指定列的语法。

  • 该语句不能使用未命名的列或重复的列名。

  • 该语句必须引用基表。

  • 该语句不能引用具有计算列的表。

  • 除非该语句使用GROUP BY表达式,否则SELECT语句中的投影列可能不包含聚合表达式。提供GROUP BY表达式时,选择列表可能包含聚合函数COUNT_BIG()或SUM()。但是,不能为可为空的列指定SUM()。该语句可能未指定HAVING,CUBE或ROLLUP。

  • SELECT语句中用作简单表达式的投影列不得出现多次。

  • 该声明不能包含PIVOT或UNPIVOT运算符。

  • 该语句不能包含UNION,INTERSECT或EXCEPT运算符。

  • 该语句不能引用视图。

  • 该语句不得包含以下任何内容:DISTINCT,COMPUTE或COMPUTE BY或INTO。

  • 该语句不能引用服务器全局变量(@@ variable_name)。

  • 该语句不能引用派生表,临时表或表变量。

  • 该语句不得引用其他数据库或服务器中的表或视图。

  • 该语句不得包含子查询,外部联接或自我联接。

  • 该语句不能引用大型对象类型:text,ntext和image。

  • 该语句不得使用CONTAINS或FREETEXT全文谓词。

  • 该语句不得使用行集函数,包括OPENROWSET和OPENQUERY。

  • 该语句不得使用以下任何聚合函数:AVG,COUNT(*),MAX,MIN,STDEV,STDEVP,VAR或VARP。

  • 该语句不得使用任何不确定的函数,包括排名和窗口函数。

  • 该语句不能包含用户定义的聚合。

  • 该语句不得引用系统表或视图,包括目录视图和动态管理视图。

  • 该语句不能包含FOR BROWSE信息。

  • 该语句不能引用队列。

  • 该语句不得包含不能更改且不能返回结果的条件语句(例如,WHERE 1 = 0)。

  • 该语句不能指定READPAST锁定提示。

  • 该语句不能引用任何Service Broker QUEUE。

  • 该语句不能引用同义词。

  • 该语句不能具有基于double / real数据类型的比较或表达式。

  • 该语句不能使用TOP表达式。


查看完整回答
反对 回复 2019-12-26
  • 3 回答
  • 0 关注
  • 832 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信