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

MySQL | 如何对查询结果进行排序

数据操作语言:结果排序 如果没有设置,查询语句不会对结果进行排序。也就是说,如果想让结果按照某种顺序排列,就必须使用 ORDER BY 子句。 SELECT .........ASC 代表升序(默认),DESC 代表降序 如果排序列是数字类型,数据库就按照数字大小排序,如果是日期类型就按日期大小排序,如果是字符串就按照字符序号排序。...默认情况下,如果两条数据排序字段内容相同,那么排序会是什么样子?...type);SHOW INDEX FROM t_message;ALTER TABLE t_message ADD INDEX idx_type(type);SQL 我们可以使用 ORDER BY 规定首要排序条件和次要排序条件...数据库会先按照首要排序条件排序,如果遇到首要排序内容相同的记录,那么就会启用次要排序条件接着排序

6.2K10

Oracle查询优化-02查询结果排序

1以指定的次序返回查询结果 问题 解决方案 总结 2按多个字段排序 问题 解决方案 总结 3按子串排序 问题 解决方案 总结 4 TRANSLATE 语法 工具 总结 5 按数字和字母混合字符串中的字母排序...问题 显示部门10中的员工姓名、职位、工资,并且按照工资升序排列,结果如下: SQL> select a.ename,a.job ,a.sal from emp a where a.deptno...-------- MILLER CLERK 1300.00 CLARK MANAGER 2450.00 KING PRESIDENT 5000.00 总结 使用order by子句可以对结果进行排序...如果在查询中使用group by 或者distinct,则不能按照select列中 ---- 2.3按子串排序 问题 按照字符串的某一部分对查询结果进行排序。...TRANSLATE 是 REPLACE 所提供的功能的一个超

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

    MySQL || 结果排序--聚集函数讲解

    MySQL 结果排序-- 聚集函数 一、环境准备 二、查询结果排序 三、查询的分组与汇总 3.1、查一下 学生们平均年龄 3.2、查一下总人数是多少 3.3、查一下每个年龄有多少人 3.4、查出最大年龄...INTO `student` VALUES (3, '小明', '男', 20, 85); INSERT INTO `student` VALUES (4, '小张', '男', 21, 87); 二、查询结果排序...语法格式: SELECT 字段名1… FROM 表名 ORDER BY 字段名1 [ASC | DESC ] ,字段名2 [ASC | DESC ]…; 字段名1 、2 是对查询结果排序的依据。...举个爪子: SELECT * FROM student ORDER BY age DESC ; 当后面跟两个排序规则的时候,是第一个字段名相同的时候,才按照第二个字段名排序规则排序。...3.5、查询出男女各多少人 select sex ,count(*) AS "人数" from student GROUP BY sex; #GROUP BY 是将结果按照 后面跟的字段名分组 3.6

    2.1K10

    解锁高效:深入MySQL JDBC流式结果

    有粉丝好友问sharding-jdbc对分库分表的逻辑表数据分页排序是如何高效实现的?答案就是分表查询+流式归并。...本文直接从MySQL JDBC的流式结果来说明流式处理,时间宝贵,case如下: try { Class.forName("com.mysql.cj.jdbc.Driver"); Connection...(Exception e) { throw new RuntimeException(e); } StatementImpl.enableStreamingResults()方法可以开启流式结果...java.sql.ResultSet.CONCUR_READ_ONLY) && (this.query.getResultFetchSize() == Integer.MIN_VALUE)); } 使用jvisualvm来对比下使用流式结果...(图1)和不使用流式结果(图2)二者的内存占用情况: 图1 图2 本次测试数据量30w+,显然使用流式结果时内存占用平稳开销小,不使用流式结果时查询结果集会一次加载到内存,内存开销较大。

    12810

    Struts2学习---result结果 result type:全局结果:动态结果带有参数的结果

    这一章节主要介绍如何配置结果,分为以下几个知识点: 结果类型(result type) 全局结果(global types) 动态结果(dynamic type) 带有参数的结果(type with...全局结果: 全局结果,顾名思义就是全局的,就像java代码里面的全局变量一样,可以在整个程序里面被调用。...所以这个时候我们就可以用到全局结果集了(全局结果在一个包里面“全局”)。...动态结果 动态结果、 struts.xml: ${r} public...这样就完成了动态的结果。 带有参数的结果 当客户端发送了一个请求,这个请求含有参数,我们将这个请求重定向到其他页面,那么我们怎么将这个参数继续带到其他页面呢?

    1.8K40

    MySQL字符及其排序规则

    MySQL 8.0.0之前的版本中,utf8mb4字符使用的是utf8mb4_general_ci排序规则。...然而,这个排序规则对于一些特定的字符比较不够准确,可能会导致一些排序和比较结果不符合预期。...---- 默认排序规则 ---- 当设置表的默认字符为utf8mb4字符但未明确指定排序规则时: 在MySQL 5.7版本中,默认排序规则为utf8mb4_general_ci。...---- 兼容性问题 ---- 由于utf8mb4_0900_ai_ci排序规则时MySQL 8.0引入的排序规则,因此将MySQL 8.0版本的表导入到MySQL 5.7或MySQL 5.6版本时,会存在字符无法识别的问题...它定义了在创建新表时使用的默认字符校对规则 查看当前MySQL服务器的collation_server的值: SHOW VARIABLES LIKE 'collation_server'; 该命令将返回一个结果

    1.7K20

    MySql-Proxy之多路结果归并 顶

    MySql-Proxy之多路结果归并 笔者觉得Cobar之类的分库分表最神奇的部分就是靠一条sql查询不同schema下(甚至不同实例下)的不同的表。...每条语句在一个DB实例上面执行后,都会返回一个ResultSet结果,在此需要将多个结果归并成一个统一的结果,然后返回client,这样client就感觉像查询一个DB实例一样。...归并ResultSet结果 在讲如何归并前,我们需要重温一下MySql返回结果的结构, 其详细描述见笔者博客: https://my.oschina.net/alchemystar/blog/834150...如果要多路归并成一路的话,field_count、fields、eof以及last_eof这些只需要返回client一份即可。...(3)LastEof阶段:最后的收尾阶段,每个结果的last_eof表示此结果的结束,只有所有的last_eof都收到之后才能表示结果的结束。

    1.5K40

    MySQL 的字符排序规则

    字符 uft8 与 utf8mb4 其实指的是 MySQL 中的字符,那到底什么是字符呢? 概念 很多人常常会把字符、字符、字符编码的概念混为一谈,今天我们仔细来看看。 何为字符?...utf8 MySQL 在创立时使用的字符就是 utf8。首先它能存储下大部分的中文汉字,对于我们正常使用肯定是绰绰有余的。...也就是说,任何不在基本多文本平面的 Unicode 字符,都无法使用 MySQL 的 utf8 字符存储。...概念 MySQl排序规则(collation),一般指对字符集中字符串之间的比较、排序制定的规则, MySLQ排序规则特征: o 两个不同的字符不能有相同的校对规则; o 每个字符有一个默认校对规则...其实对于排序规则的细节问题,我们关注较少,反而对排序规则中是否涉及大小写敏感关注较多。 例如,系统使用 utf8 字符,若使用 utf8_bin 排序规则,执行 SQL 查询时区分大小写。

    2.4K20

    MySQL原理 - 字符排序规则

    任何计算机存储数据,都需要字符,因为计算机存储的数据其实都是二进制编码,将一个个字符,映射到对应的二进制编码的这个映射就是字符编码(字符)。这些字符如何排序呢?决定字符排序的规则就是排序规则。...只修改比较规则,则字符将变为修改后的比较规则对应的字符。 实例级别 通过两个系统变量来指定实例级别的字符排序规则。...,并不会更新老表的字符还有排序规则。...表级别 可以在创建时指定字符集合排序规则,不指定的话,用数据库的字符还有排序规则,也可以修改字符排序规则。...列级别 可以在创建表的时候,指定不同的列有不同的字符排序规则,也可以修改列的字符排序规则: mysql> create table test (name varchar(32) character

    3.1K10

    MyBatis结果映射

    ---- MyBatis结果映射配置 当我们表格的字段名称与字段封装类里的属性名称对应不上的时候,我们就得在配置文件中手动配置结果对对象属性的映射,不然MyBatis是不会自动映射的,得出来的就会是一个空对象...public interface StudentMapper { public Student selectById(int id); } 可以看到对象属性名称与表格字段名称不一致,这时候就需要配置结果的映射器...","stuAddress":"深圳","id":24,"stuAge":20} 如果我们需要进行连接查询的时候,也需要用到结果映射,例如我现在要查询student表与studentlog中sid一致的记录...private StudentLog studentLog; ... getter setter 略 ... } 然后需要在XML文件中使用association标签来配置连接查询的结果映射...从以上简单的示例中,可以看到association标签完成的是一对一的级联操作的结果映射,如果是一对多的操作时就需要使用collection标签进行结果的映射。

    80120

    一个分页排序SQL查询结果不确定的案例

    因此,对于第二个查询语句,Oracle最内层返回中间层的是所有满足条件的数据,而中间层返回最外层的也是所有数据。数据的过滤在最外层完成,显然这个效率要比第一个查询低得多。...(此处原文有一些限定条件,确保第一条SQL的结果肯定包含第二条和第三条的结果,即CLS_CODE=B应该只有一条记录在第二条或第三条SQL的结果集中。)...ROWNUM是在他传向查询的谓词阶段之后被赋予结果的某行记录上,而且这之后才会继续执行排序或聚集等操作,例如如下SQL select ..., ROWNUM from t where <where...,第四步会对这个结果按照t.code, t.o_stn, t.d_stn, t.first_date, t.eff_date这些字段依次做排序了,我们再结合这张表的属性,order by的这些字段没有一个能保证值唯一...这就可以证明order by字段有重复值的情况下,查询结果的顺序是不确定的,进而我们可以推测,order by字段值的重复度和结果不确定性的程度有关,如果order by字段值没有重复的,则结果就是确定的

    1.4K30

    Mysql常用sql语句(7)- order by 对查询结果进行排序

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 通过select出来的结果是按表中的顺序来排序的...,order by允许我们对查询结果针对某个字段进行排序 实际场景:根据数据的创建时间、更新时间、文件大小、商品价格等字段来排序 order by的语法格式 ORDER BY [,...[ASC | DESC] ASC:升序排序,默认值 DESC:降序排序 注意点 order by关键字后可以跟子查询(后面展开讲) 如果字段值是NULL,则当最小值处理 如果指定多个字段排序,则按照字段的顺序从左往右依次排序...多字段排序的栗子 先根据sex倒序排序,然后根据height升序排序 select * from yyTest order by sex desc, height asc; ?...知识点 对多个字段排序时,只有第一个排序字段有相同的值,才会对第二个字段进行排序,以此类推 如果第一个排序字段的所有数据都是唯一的,将不会对第二个排序字段进行排序,以此类推 按字母(A-Z进行排序,大小写不敏感

    2.8K30

    结果IMultipleResult接口

    在某些任务中,需要执行多条sql语句,这样一次会返回多个结果,在应用程序就需要处理多个结果,在OLEDB中支持多结果的接口是IMultipleResult。...它可取的值有下面几个: DBPROPVAL_MR_SUPPORITED:支持多结果 DBPROPVAL_MR_SONCURRENT:支持多结果,并支持同时打开多个返回的结果(如果它不支持同时打开多个结果的话...,在打开下一个结果之前需要关闭已经打开的结果) DBPROPVAL_MR_NOTSUPPORTED: 不支持多结果 这个属性可以通过接口IDBProperties接口的GetProperties...] interface ISupportErrorInfo; } 一般在程序中,使用多结果有如下步骤 查询数据源是否支持多结果,如果不支持则要考虑其他的实现方案 如果它支持多结果,在调用ICommandText...循环调用接口的GetResult方法获取结果对象。

    1.1K20
    领券