SQL2005下字符串字段内的字符排序
来源:互联网 发布:three.js 顶点数 编辑:程序博客网 时间:2024/06/07 12:51
SQL2005下字符串字段内的字符排序
今天和梁翁在群里聊天,小家伙突然抛出一个有意思的问题,那就是字符串字段内的字符串排序问题,比如有列col,有数据'RDGS' ,要求输出为'DGRS'。
当时我本想和梁翁讨论一种思路,那山羊闹着要聊天,不许讨论技术问题,所以这夜深时俺整理一下,与大家分享。
-----------------------------------------------------------------------
-- Author: happyflystone
-- Date : 2009-01-17 22:56:11
-- Ver: Microsoft SQL Server 2005 - 9.00.2047.00 (Intel X86)
-- Apr 14 2006 01:12:25
-- Copyright (c) 1988-2005 Microsoft Corporation
-- Standard Edition on Windows NT 5.0 (Build 2195: Service Pack 4)
--
----------------------------------------------------------------------
--测试数据
DECLARE @T TABLE(COL VARCHAR(10))
INSERT @T SELECT 'WEFSA'
INSERT @T SELECT 'DFSA'
INSERT @T SELECT 'DQWF'
--数据生成
;
WITH T
AS
(
SELECT top 26 ROW_NUMBER() OVER (ORDER BY ID) AS n
FROM SYS.SYSOBJECTS
),
T2
AS
(
SELECT col,CHAR(64+N) AS M,N
FROM @T JOIN T
ON CHARINDEX(CHAR(64+N),COL) > 0
)
SELECT
COL,
replace(
(SELECT M as [data()] FROM T2 WHERE COL = T3.COL ORDER BY N FOR XML PATH('')
),' ','') AS NEWCOL
FROM @T T3
--结果
/*
COL NEWCOL
---------- --------
WEFSA AEFSW
DFSA ADFS
DQWF DFQW
(3 行受影响)
*/
--附录:(小P梁写的,也就是梁翁了,大家自己比吧)
;WITH Numbers AS
(
SELECT TOP(20)
ROW_NUMBER() OVER(ORDER BY [object_id]) AS ID
FROM sys.objects
),
Liang AS
(
SELECT
A.col,
B.ID,
SUBSTRING(A.col,B.ID,1) AS v
FROM @t AS A
JOIN Numbers AS B
ON SUBSTRING(A.col,B.ID,1)<>''
)
SELECT
col,
REPLACE(
(
SELECT
v AS [data()]
FROM Liang
WHERE col=A.col
ORDER BY v
FOR XML PATH('')
),' ','')
FROM @t AS A
- SQL2005下字符串字段内的字符排序
- 再议SQL2005下字符串字段内的字符排序
- 换个思路"SQL2005下字符串字段内的字符排序"
- Oracle字符串字段内的字符排序
- Oracle字符串字段内的字符排序
- SQL字符串字段内的字符排序
- SQL批量更改用户表内字符型字段的排序规则
- SQL批量更改用户表内字符型字段的排序规则
- SQL批量更改用户表内字符型字段的排序规则
- 内排序- 字符串处理 字符与数字之间的对应关系
- SQL2005中替换字段中的字符串
- 将SQL2005字符型字段转换成为日期时间型后比较大小的代码
- 判断一个字符串内字符重复的字符个数
- 练习5-17 增加字符段处理功能,以使得排序程序可以根据行内的不同字段进行排序,每个字段按照一个单独的选项集合进行排序
- Java根据容器(List,ArrayList)内对象的字段排序
- PHP数组根据数组内的某个单元字段排序
- Oracle 分组内排序 字段相同的排在一起显示
- PHP数组根据数组内的某个单元字段排序
- 关于使用showModalDialog传递参数出现中文乱码问题
- vim tips
- Oracle学习笔记八:安全管理
- WPF/Silverlight中的Command
- 呃,好晚了
- SQL2005下字符串字段内的字符排序
- 我的Emacs配置存放
- 090117.成长日记
- 有点sexy的iPhone应用程序
- Flash P2P 通信技巧(AS-Java-AS)
- 用modbus协议,在S7-300中实现与PC,以及英杰电机调速器三点通讯
- ORA-28000: the account is locked(通过plsql解决的方法)
- 家乐福选用Teradata数据仓库平台支持营销
- 高航的离别的秋天 很不错!