【SQL】按照特定所需的元素排序

Oracle中,平时我们排序常用“Order by 列名” 的方式来排序,但是有的时候我们希望这个列中的某些元素排在前面或者后面或者中间的某个位置。

这时我们可以使用Order by case when then方法。

举例:我们希望本部门的领导的名字在前面。

Select * from parter where lvl=‘leader‘ order by ( case when name in(‘zhangsan‘,‘lisi‘,‘wangermazi‘) then 0 else 1 end)

实现的效果是:‘zhangsan‘,‘lisi‘,‘wangermazi‘  从头到尾依次排序,剩下的元素排在这三个元素的后面随机排序。把1和0替换,又变成了‘wangermazi’,‘lisi‘,‘zhangsan‘的顺序倒序排序了。

0是我们需要的元素的位置,1是其他元素的位置。

同样的效果我们也可以通过“decode”函数实现

Select * from parter where lvl = ‘leader‘ order by decode(name,‘zhangsan‘,0,‘lisi‘,1,‘wangermazi‘,2,3)

实现的效果与上面相同,其中0,1,2是我们需要的三个元素的位置,3是其他元素的位置。

但是第一个SQL语句有一个问题,如果name字段就只有这三个元素,那么when 完全满足条件,这样这三个元素就变成随机排序了。

所以如果使用case 函数,最好是使用这种方式

Select * from parter where lvl=‘leader‘ order by (case when name=‘zhangsan‘ then 0 when name=‘lisi‘ then 1 name=‘wangermazi‘ then 2 else 3 end)

如此,即便name字段只有三个元素,也能按照我们的需求排序了。

需要注意的是,只有我们需要的三个元素是按照我们的所定义的顺序排序的,其余元素是随机排序的,如果我们需要其余元素按照某个字段顺序或者倒序排序,只需要在最后面加逗号字段名即可。

Select * from parter where lvl=‘leader‘ order by (case when name=‘zhangsan‘ then 0 when name=‘lisi‘ then 1 name=‘wangermazi‘ then 2 else 3 end),id desc

decode函数相同

Select * from parter where lvl = ‘leader‘ order by decode(name,‘zhangsan‘,0,‘lisi‘,1,‘wangermazi‘,2,3),id desc

由上面的例子我们知道,那些数字就是元素的位置,而如果我们要把自己需要的元素排最后面呢。

只需要改改数字就行了。

case 函数

Select * from parter where lvl=‘leader‘ order by (case when name=‘zhangsan‘ then 3 when name=‘lisi‘ then 2 name=‘wangermazi‘ then 1 else 0 end).id desc

decode函数相同

Select * from parter where lvl = ‘leader‘ order by decode(name,‘zhangsan‘,3,‘lisi‘,2,‘wangermazi‘,1,0),id desc

而强大的decode函数还为我们可以将余下的元素按照自己的想法排序。

假如我们要把‘zhangsan‘和‘lisi‘排最后,而把‘wangermazi‘排第一,这时我们可以同时使用两个decode函数

Select * from parter where lvl = ‘leader‘ order by decode(name,‘zhangsan‘,3,‘lisi‘,2,0),decode(name,‘wangermazi‘,1),id desc

如此我们便实现了张三和李四分别排倒数第一和倒数第二,王二麻子排第一,其余元素按照id倒序排列。

如此我们便实现了自己需要的元素按照特定的顺序排序。

时间: 2024-08-10 16:59:16

【SQL】按照特定所需的元素排序的相关文章

SQL:无法解决 equal to 操作的排序规则冲突。

更改存储过程的时候,在SQL中出现了 “无法解决 equal to 操作的排序规则冲突”错误,网上搜之,发现是表之间元素创建时排序规则不同(一个是collate Chinese_PRC_CI_AI_WS,一个为COLLATE SQL_Latin1_General_CP1_CI_AS) COLLATE 一个子句,可应用于数据库定义或列定义以定义排序规则,或应用于字符串表达式以应用排序规则投影. 一般解决办法: 直接在报错处的关联字段后加上collate Chinese_PRC_CI_AI_WS就可

oc-数组内元素排序

#import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { @autoreleasepool { //数组内元素排序 NSArray *arr=@[@"MON",@"TUE",@"WED",@"THU",@"FRI",@"SAT",@"SUN"]; NSArray

数组内元素排序及数组排序

#define NSLog(FORMAT, ...) fprintf(stderr,"%s\n",[[NSString stringWithFormat:FORMAT, ##__VA_ARGS__] UTF8String]); #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { @autoreleasepool { NSArray *[email protected][@&q

Python对列表中字典元素排序

问题起源 json对象a,b a = '{"ROAD": [{"id": 123}, {"name": "no1"}]}' b = '{"ROAD": [{"name": "no1"}, {"id": 123}]}' 特点:a,b对应的Python的对象中键对应的键值——列表中包含着相同的字典元素,但是唯一不同的是顺序不同.如果忽略顺序,如何判断两

运行sql server profiler所需的权限

/********运行Sql Server Profiler所需的权限(performance)*********/ --EG.-- 使用TRACE帐户(Performancetest)跟踪Sql Server事件.-- 创建TRACE登陆帐户(Performancetest),并授予其 ALTER TRACE和VIEW SERVER STATE的权限. USE Master CREATE LOGIN Performancetest WITH PASSWORD='[email protected

SQL 用中文的拼音和笔画排序

SQL 用中文的拼音和笔画排序 城市按拼音排序: SELECT chineseName FROM [表名] order by chinesename collate Chinese_PRC_CS_AS_KS_WS asc 城市按笔划排序: SELECT chineseName FROM [表名] order by chinesename collate Chinese_PRC_Stroke_CS_AS_KS_WS   asc 以上代码中GD上调试通过. 多说两句,排序规则名称由两部份构成,前半部

从单链表中删除最大的元素,单链表元素排序

public class LinkList { public Node head; public LinkList() { head = new Node(); head.next = null; } //尾插法 public void createByTail(int[] arr, int n) { Node tail = head; for(int i=0; i<n; i++) { Node c = new Node(arr[i]); tail.next = c; tail = c; } t

SQL Server数据库培训(SQL篇)----Select语句构成元素

1.             Select语句构成元素 1.1          Select * 避免使用select * 当你想在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用 '*' 是一个方便的方法.不幸的是,这是一个非常低效的方法. 实际上,SQL在解析的过程中, 会将'*' 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间. 1.2          Select语句中元素的执行顺序 为了描述逻辑查询处理和各种SELECT查询子句

二维数组元素排序

<script type="text/javascript">//--------------------------1数值排序-------------------------var arr1=[[22,33,44],[1,0,6,2],[33,10],[10,5]];arr1.sort(function(x,y){ return x[1] -y[1];//按照二维数组arr1中每个数组元素(数组)的第二个元素升序排列 });console.log(arr1); //--