c# – SQL用户定义的聚合顺序值保留?

前端之家收集整理的这篇文章主要介绍了c# – SQL用户定义的聚合顺序值保留?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Im使用 this MSDN page中的代码创建用户定义的聚合,以将字符串与sql Server中的group by进行连接.我的一个要求是,连接值的顺序与查询中的顺序相同.例如:
  1. Value Group
  2. 1 1
  3. 2 1
  4. 3 2
  5. 4 2

使用查询

  1. SELECT
  2. dbo.Concat(tbl.Value) As Concat,tbl.Group
  3. FROM
  4. (SELECT TOP 1000
  5. tblTest.*
  6. FROM
  7. tblTest
  8. ORDER BY
  9. tblTest.Value) As tbl
  10. GROUP BY
  11. tbl.Group

会导致:

  1. Concat Group
  2. "1,2" 1
  3. "3,4" 2

结果似乎总是出来正确和正如预期的,但比我碰到this page说,订单不能保证,并且该属性sqlUserDefinedAggregateAttribute.IsInvariantToOrder仅保留供将来使用.

所以我的问题是:假设字符串中的连接值可以以任何顺序结束,是否正确?如果是这样,为什么MSDN页面上的示例代码使用IsInvariantToOrder属性

解决方法

我怀疑这里的一个大问题是您的陈述“与查询中相同” – 但是,您的查询从未定义(并且无法定义)通过聚合的事物的顺序(您当然可以通过订购ORDER BY之后GROUP BY).除此之外,我只能说它完全基于一个集合(而不是一个有序的序列),而且技术上这个顺序确实是不确定的.

猜你在找的C#相关文章