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

王朝mssql·作者佚名  2006-12-17
窄屏简体版  字體: |||超大  

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

如果对字符型编号字段(如1-2)进行排序 问题说明:

解决方法:

(

@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- 王朝網路 版權所有 導航