zoukankan      html  css  js  c++  java
  • SQL Server 自定义排序

    方法一:
    比如需要对SQL表中的字段NAME进行如下的排序:
        张三(Z)
        李四(L)
        王五(W)
        赵六(Z)

    按照sql中的默认排序规则,根据字母顺序(a~z)排,结果为:李四 王五 赵六 张三

    自定义排序:order by charindex(NAME,‘张三,李四,王五,赵六’)

    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)

  • 相关阅读:
    职业规划 !!
    linux上ssh配置指南
    低内存VPS用轻量级的Dropbear替换OpenSSH
    修改shell终端提示信息
    减少windows7内存占用的优化方案(内存占用才285兆 比XP还省)
    linux下提示符修改
    mysql存储过程学习笔记区块,条件,循环
    Apache下实现禁止目录浏览
    [学习指导] linux 启动过程以及 /etc/rc.d/init.d/目录的一点理解
    mysql 5.0存储过程学习总结
  • 原文地址:https://www.cnblogs.com/wangqilong/p/12540354.html
Copyright © 2011-2022 走看看