Im使用
this MSDN page中的代码创建用户定义的聚合,以将字符串与sql Server中的group by进行连接.我的一个要求是,连接值的顺序与查询中的顺序相同.例如:
- Value Group
- 1 1
- 2 1
- 3 2
- 4 2
使用查询
- SELECT
- dbo.Concat(tbl.Value) As Concat,tbl.Group
- FROM
- (SELECT TOP 1000
- tblTest.*
- FROM
- tblTest
- ORDER BY
- tblTest.Value) As tbl
- GROUP BY
- tbl.Group
会导致:
- Concat Group
- "1,2" 1
- "3,4" 2
结果似乎总是出来正确和正如预期的,但比我碰到this page说,订单不能保证,并且该属性sqlUserDefinedAggregateAttribute.IsInvariantToOrder仅保留供将来使用.
所以我的问题是:假设字符串中的连接值可以以任何顺序结束,是否正确?如果是这样,为什么MSDN页面上的示例代码使用IsInvariantToOrder属性?