首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL ORDER BY IF() 条件排序

在做sqlzoo的时候,碰到一个SQL的排序问题,他把符合条件的单独几行,可以放在查询结果的开始,或者查询结果的尾部 通过的方法就是IN语句(也可以通过IF语句) 自己做了个测试,如下,这个是表的所有内容...正如上面一段说的,你可以把if 语句看成是独立的column,所以你也可以为他添加排序条件ASC或者DESC,当然默认是ASC,可以不写。...这样,查询就等于第一步是查询隐藏属性0,1,然后进行DESC排序,因为species=snake的返回值是0,所以进行倒序排列时,就被排在了最后 以此类推,你在进行隐藏属性优先排序的同时,对于剩下的排序...使用ORDER BY配合IN语句 上面一个是满足单个条件,返回0或者1,那如果需要用到一个范围呢?...这样的话,birth IN语句会进行判断,如果birth满足条件,返回1,不满足,返回0 所以,满足条件的两行,因为返回值是1,进行ASC排序的时候,就被放置在了最后。

3.7K50

MySQL根据输入的查询条件排序

姓名的输入框输入的是(zhangsan,lisi),那么返回的结果也要是按照(zhangsan,lisi)这样的顺序展示 测试 有如下表classroom,内容如下 如果根据字段名称去查,那么它会根据字典顺序排序...如下所示 select * from classroom where classname in ("class2","class3") order by classname 如果想根据我in里面的顺序去排序...where classname in ("class2","class3") order by field(classname,"class3","class2") 如果我想在原来的基础上,在根据时间排序..."class2","class3") order by field(classname,"class3","class2") ,createTime 注意: 如上面的SQL所示,by field里的 条件必须比...in 里面的查询条件多,如果少一个,那么这个排序就不会成功 //成功 select * from classroom where classname in ("class2","class3") order

19910
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql条件函数

    ——周国平《风中的纸屑》 在我们日常开发,有时可能会在SQL写一些条件,例如这里一个例子 这里有这样一张表,数据如下: 如果我们需要把未认证(状态为NOT_AUTH)的用户放到前面排序显示,在不影响分页的情况下...我们可以这么写 SELECT *,IF(status='NOT_AUTH','NOT_AUTH',null) AS sort FROM `user` ORDER BY sort DESC 这里使用到了MYSQL...的IF函数 IF([条件],[为true时值],[为false时值]) 例如我们需要整体排序,认证的在最前,然后是未认证的,最后是已认证的 我们则可以使用MYSQL的CASE、WHEN、THEN、ELSE...WHEN STATUS = 'HAS_AUTH' THEN 2 ELSE 999 END ) AS sort FROM `user` ORDER BY sort ASC 这里 CASE WHEN [条件...1] THEN [条件1满足时值] WHEN [条件2] THEN [条件2满足时值] WHEN [条件3] THEN [条件3满足时值] ELSE [条件都不满足时值] END Tips:在除了查询语句中

    3.4K10

    Swift 如何进行多重条件排序

    这里我们一个简单的 BlogPost 结构体,它包含帖子标题和两个统计数据,即浏览次数pageView和会话持续时间sessionDuration。...在这种情况下,需要根据另一个条件或属性来进行进一步的排序。 我们将在本文中讨论这种多属性排序。他们各种各样的方法来解决这个问题。我将展示没有任何复杂概念的最基本的方法。...什么是多条件排序 ---- 多条件排序是指我们比较第一个条件排序,只有当第一个条件相等时,我们才转到下一个条件。我们这样做直到找到一个不相等的条件。...按照两个字段对object数组进行排序 ---- 我们使用前面提到的场景,我们希望根据表现对BlogPost进行排序。...---- 不难发现,根据两个条件排序非常简单。

    1.2K20

    Pythonif多个条件处理方法

    Pythonif多个条件怎么办 pythonif多个条件,可以使用and、or、elif关键字来连接。...Python 编程 if 语句用于控制程序的执行,基本形式为: if 判断条件: 执行语句……else: 执行语句…… if 语句的判断条件可以用 (大于)、<(小于)、==(等于)、 =(大于等于...当判断条件为多个值是,可以使用以下形式: if 判断条件1: 执行语句1……elif 判断条件2: 执行语句2……elif 判断条件3: 执行语句3……else: 执行语句4…… 示例 1、使用and...: if 判断条件: 执行语句…… else: 执行语句…… 其中”判断条件”成立时(非零),则执行后面的语句,而执行内容可以多行,以缩进来区分表示同一范围。...到此这篇关于Pythonif多个条件处理方法的文章就介绍到这了,更多相关Pythonif多个条件怎么办内容请搜索ZaLou.Cn以前的文章或继续浏览下面的相关文章希望大家以后多多支持ZaLou.Cn

    26.2K20

    MySQL学习笔记汇总(一)——简单查询、条件查询、数据排序

    select empno, ename from emp; 列出员工的编号,姓名和年薪 select empno,ename,sal*12 as ‘年薪’ from emp; 二、条件查询...语法格式: select 字段,字段… from 表名 where 条件; 执行顺序:先from,然后where,最后select 支持的运算符: in和or效率问题: in...emp where sal not in(1600,3000); 查询姓名以 M 开头所有的员工 select * from emp where ename like ‘M%’; 查询姓名第二个字符为...A 的所有员工 select * from emp where ename like ‘_A%’; 三、数据排序 排序采用 order by 子句,order by 后面跟上排序字段,排序字段可以放多个...间隔,order by 默认采用升序,如果存在 where 子句那么 order by 必须放到 where 语句的后 面 ASC:升序 DESC: 降序 执行顺序: 案 例: 按照薪水由小到大排序

    1.1K40

    mysql的field()排序函数

    field() 函数:是将查询的结果集按照指定顺序排序 格式: FIELD(str,str1,str2,str3,...)...str是字段名字,字符串str1,str2,str3等等,是该字段的值 函数意思: 匹配到str1,将其放到结果集最后返回 详细解析: 当字段值没有匹配到str1,str2或者str3的时候,按照正常排序...;当匹配到这些的时候,会把没有匹配的值放到最前面,匹配到的放到后边,并且以写的顺序排序返回结果集。...场景: 数据库字段model,代表手机型号,值很多,和更多型号;现在根据model字段排序,查询结果集中,’‘更多型号’’ 必须放最后。...ORDER BY FIELD(model,'更多型号') sql中排序比较常见,我们常用的排序语句是这两个

    39450

    MySQL两个小的优化案例

    MySQL两个小的优化案例 今天介绍两个优化案例,一个是关于min和max这种函数的,另外一个是关于count这个计数函数的。...where条件写的是name列,所以MySQL会走一次全表扫描,这我们从执行计划也可以看出来, mysql:yeyztest 23:25:30>>explain select min(id) from...我们知道,count(*)的写法会扫描全表,在Innodb和MyIsam对这个函数的处理不同,MyIsam可以非常快的得到这个结果,而不用扫描整个表。...在MyIsam的存储引擎下,例如我们想要统计一个100w数据记录的表id>5的值,正常情况下,我们几乎要扫描全部的记录,基于MyIsam的特性,我们可以这样写来实现对它的优化: mysql:yeyztest...这个例子,test_1表中有43条记录。反向搜索之后,原来需要过滤38条记录,一下子变成了4条记录,这个提升已经很明显了。

    46810

    多个字段如何按其中两个进行排序(二次排序

    多个字段如何按其中两个进行排序(二次排序) 1 原理     二次排序就是首先按照第一字段排序,然后再对第一字段相同的行按照第二字段排序,注意不能破坏第一次排序的结果。     ...这里主要讲如何使用一个Mapreduce就可以实现二次排序。Hadoop自带的SecondarySort程序,但这个程序只能对整数进行排序,所以我们需要对其进行改进,使其可以对任意字符串进行排序。...下面会分别列出这两个程序的详解。       ...在第一个 例子,使用了IntPair实现的compareTo方法,而在下一个例子,专门定义了key比较函数类。      ...2 Hadoop自带的只对两个整型进行排序例子详解 2.1 测试数据如下所示: 20 21 50 51 50 52 50 53 50 54 60 51 60 53 60 52 60 56 60 57

    4.8K80

    MySQLWHERE后跟着N多个OR条件会怎样。。。

    某工具在运行过程,会产生下面的SQL进行查询,WHERE后跟了N多个条件mysql> select * from order_line where (ol_w_id = '1' and ol_d_id...问题分析 只需要扫描 7.5万行记录,501个page,返回8192行结果,正常情况下不应该需要这么久才对,肯定是哪里问题。...当WHERE查询条件很多OR、AND组成时,优化器判断超过内存消耗限制,则会调整SQL执行计划,变成其他执行方案,甚至可能是全表扫描。...相当于做了1万次索引列等值条件查询。 查询效率提升非常显著。 进一步优化 线上生产环境,各式各样的SQL层出不穷,这次可能是一万条OR条件,下次可能是其他的,是不能无限度增加数据库内存消耗的。...针对本案的SQL,更好的优化办法是找出这些OR条件的范围规律,并改写成一条更简单的SQL,类似下面这样: mysql> select * from order_line where ol_w_id =

    1.6K20
    领券