c# – SQL用户定义的聚合顺序值保留?
发布时间:2020-12-15 03:41:55 所属栏目:百科 来源:网络整理
导读:Im使用 this MSDN page中的代码创建用户定义的聚合,以将字符串与SQL Server中的group by进行连接.我的一个要求是,连接值的顺序与查询中的顺序相同.例如: Value Group1 12 13 24 2 使用查询 SELECT dbo.Concat(tbl.Value) As Concat,tbl.GroupFROM (SELECT T
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属性? 解决方法
我怀疑这里的一个大问题是您的陈述“与查询中相同” – 但是,您的查询从未定义(并且无法定义)通过聚合的事物的顺序(您当然可以通过订购ORDER BY之后GROUP BY).除此之外,我只能说它完全基于一个集合(而不是一个有序的序列),而且技术上这个顺序确实是不确定的.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |