sql 自定义排序

发布时间:2018-10-24编辑:admin阅读(1869)

测试数据

CREATE TABLE UserTable
(
    Name VARCHAR(50)
)
INSERT INTO dbo.UserTable(Name)
VALUES('张三' -- Name - varchar(50)
    )
INSERT INTO dbo.UserTable(Name)
VALUES('李四' -- Name - varchar(50)
    )
INSERT INTO dbo.UserTable(Name)
VALUES('王五' -- Name - varchar(50)
    )
INSERT INTO dbo.UserTable(Name)
VALUES('赵六' -- Name - varchar(50)
    )

未排序

SELECT * FROM dbo.UserTable

按Name排序

SELECT * FROM dbo.UserTable ORDER BY Name

自定义排序

方法一:

SELECT * FROM dbo.UserTable ORDER BY CHARINDEX(NAME,'张三李四王五赵六')

CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用方法如下:
CHARINDEX ( expression1 , expression2 [ , start_location ] )
Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。
CHARINDEX函数返回一个整数,返回的整数是要找的字符串在被找的字符串中的位置。假如CHARINDEX没有找到要找的字符串,那么函数返回整数“0”。让我们看看下面的函数命令执行的结果:

SELECT CHARINDEX('SQL', 'Microsoft SQL Server')

这个函数命令将返回在“Microsoft SQL Server”中“SQL”的起始位置,在这个例子中,CHARINDEX函数将返回“S”在“Microsoft SQL Server”中的位置11。

SELECT CHARINDEX('7.0', 'Microsoft SQL Server 2000')

在这个例子中,CHARINDEX返回0,因为字符串“7.0” 不能在“Microsoft SQL Server”中被找到。

方法二:

SELECT * from UserTable 
ORDER BY (CASE Name WHEN '张三' THEN 1 WHEN '李四' THEN 2 WHEN '王五' THEN 3 WHEN '赵六' THEN 4 ELSE 0 END)


  关键字:sql自定义排序


鼓掌

0

正能量

0

0

呵呵

0


评论区