如果对字符型编号字段(如1-2)进行排序

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

问题说明:

在开发中经常遇到要对“1-2”、“1-15”或“1.2”、“1.15”这样的数据字段进行排序,而这样的字段不能直接通过ORDER BY的方式来排序。

解决方法:

通过一个用户函数将此类数据字段变成输出成直接可以排序的的字段:

CREATE FUNCTION dbo.GetNumberOrderString

(

@NumberString NVARCHAR(200), --待处理字符

@SplitChar NVARCHAR(10) = '-', --分隔符

@Length INT = 2 --每段的字符长度

)

RETURNS NVARCHAR(500) AS

BEGIN

DECLARE @Result NVARCHAR(500) -- 结果

SET @Result = ''

DECLARE @F INT -- 第一个分隔字符的位置

WHILE LEN(@NumberString) > 0

BEGIN

-- 取出字符串

SET @F = CHARINDEX(@SplitChar, @NumberString) --取第一个分隔串的位置

--PRINT @F

DECLARE @V NVARCHAR(100)

IF @F = 0

BEGIN

SET @V = @NumberString

--PRINT @V

SET @NumberString = ''

--PRINT @NumberString

END

ELSE

BEGIN

SET @V = SUBSTRING(@NumberString, 0, @F ) --取第一个分隔串的之前值

--PRINT @V

SET @NumberString = SUBSTRING(@NumberString, @F + 1, LEN(@NumberString) - @F) --取第一个分隔串之后的值

--PRINT @NumberString

END

-- 按长度对齐字符串

-- IF LEN(@V) > @Length RAISERROR('对齐的长度超出范围', 1, 1)

IF ISNUMERIC(@V) = 1 SET @V = REPLICATE('0', @Length - LEN(@V)) + @V

ELSE SET @V = @V + REPLICATE('0', @Length - LEN(@V))

SET @Result = @Result + @V

END

RETURN @Result

END

使用实例:

SELECT * FROM item ORDER BY dbo.GetNumberOrderString(id, '-', 3)

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航