当前位置:Gxlcms > 数据库问题 > sql 自定义排序

sql 自定义排序

时间:2021-07-01 10:21:17 帮助过:2人阅读

 
CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用方法如下:
       CHARINDEX ( expression1 , expression2 [ , start_location ] )
       Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。
       CHARINDEX函数返回一个整数,返回的整数是要找的字符串在被找的字符串中的位置。假如CHARINDEX没有找到要找的字符串,那么函数整数“0”。让我们看看下面的函数命令执行的结果:
      CHARINDEX(‘SQL‘, ‘Microsoft SQL Server‘)
      这个函数命令将返回在“Microsoft SQL Server”中“SQL”的起始位置,在这个例子中,CHARINDEX函数将返回“S”在“Microsoft SQL Server”中的位置11。
接下来,我们看这个CHARINDEX命令:
      CHARINDEX(‘7.0‘, ‘Microsoft SQL Server 2000‘)
      在这个例子中,CHARINDEX返回零,因为字符串“7.0” 不能在“Microsoft SQL Server”中被找到。接下来通过两个例子来看看如何使用CHARINDEX函数来解决实际的T-SQL问题。   方法二: 针对表table_example的class字段排序,class字段值为:A、B、C、D。用户要求table_example中的数据按照class字段值C、A、D、B的顺序排序。    

select * from teble_exaple
order by( 

case class
       
when ‘C‘ then 1,
       
when ‘A‘ then 2,
       
when ‘D‘ then 3,
       
when ‘B‘ then 4
   
else ‘‘
end
)   方法三: 利用decode函数:   select * from table_example order by decode(class,‘C‘,1,‘A‘,2,‘D‘,3,‘B‘,4)  

sql 自定义排序

标签:

人气教程排行