首页
学习
活动
专区
圈层
工具
发布

rownum的SQL需求

《从一条"错误"的SQL,了解rownum的作用》提到的案例中,原始需求是:检索name是(aaa或者bbb)的前10条记录,其中一种写法,如下, ?...现在的问题,就是如何同“name是aaa”的所有记录,进行整合。相当于合并两个结果集,用的连接关键字,肯定是OR,“前10条name是bbb”,可以考虑使用rowid,直接定位结果集。...在这个结果集上,进行过滤,一个条件是name='aaa'的,另一个是name='bbb' and rownum的记录,已经排在前面,所以使用rownum的,10条bbb的,总计29条,但是和写法一不同的是,记录的顺序,由于子查询出来的结果集,按照name排序,因此得到的结果,就会排序, ?...当然,为了实现“检索name是aaa的所有记录,以及前10条name是bbb的”的需求,上面只是可能的两种方法,朋友们要感兴趣,可以发出来你们的方法,看看是否有更便捷的?

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

    MySQL执行sql语句的机制

    查询缓存: 执行查询语句的时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。...分析器: 没有命中缓存的话,SQL 语句就会经过分析器,分析器说白了就是要先看你的 SQL 语句要干嘛,再检查你的 SQL 语句语法是否正确。...第一步,词法分析,一条 SQL 语句有多个字符串组成,首先要提取关键字,比如 select,提出查询的表,提出字段名,提出查询条件等等。做完这些操作后,就会进入第二步。...第二步,语法分析,主要就是判断你输入的 sql 是否正确,是否符合 MySQL 的语法。 优化器: 按照 MySQL 认为最优的方案去执行。 执行器: 执行语句,然后从存储引擎返回数据。...2 执行过程 查询语句的执行: 1、鉴权 2、查询缓存 3、分析sql,提取关键字select 、表名、列字段、查询条件,然后判断语法 4、优化执行方案,自己的优化算法不一定是最优 5、再次权限校验

    4.6K30

    mysql优化sql语句的方法

    b)  用下面的语句替换: select num from a where exists(select 1 from b where num=a.num)  14.并不是所有索引对查询都有效,SQL...mysql优化 2、数据库优化的目标?...通过各种对数据库的优化方法,获取最高的查询和加载性能,达到查询性能的提高和加载性能的提高。 3、掌握优化的方式和途径 建表、索引、配置、SQL语句都需要优化 4、掌握建表和分表优化?...原本存储于一个表的数据分块存储到多个表上 5、掌握数据库的查询优化 ①关键字一般放在SELECT查询语句的前面,用于描述MySQL如何执行查询操作、以及MySQL成功返回结果集需要执行的行数。...5、掌握MySQL数据库的索引优化 6、掌握数据库的配置优化 7、掌握数据库的查询优化 一般来说,要保证数据库的效率,要做好以下四个方面的工作:数据库设计、sql语句优化、数据库参数配置、恰当的硬件资源和操作系统

    1.6K20

    mysql语句和sql语句的区别_mongodb和mysql的区别

    大家好,又见面了,我是你们的朋友全栈君。 MySQL和SQL之间的区别有哪些?很多PHP的初学者,对MySQL,MyAdmin和SQL有什么区别并不是很清楚?...SQL由ISO(国际标准化组织)标准化,和其他数据库中几乎是相同的方式运行,SQL大致分为三种语言。它在控制和操作数据库时使用,它是一种在所有语句中组合动词和对象的语法。...值得注意的是,MySQL使用了几个扩展来增强SQL Server标准。因此,将MySQL应用程序移植到Microsoft SQL Server或竞争的SQL数据库引擎需要相当大的努力。...三:MySQL和SQL之间的区别 两者最大的区别就是MySQL是开源,但是两者都是关系型数据库,目前有很多人使用这两种数据库,具体请看以下图: 结论: SQL是一种用于操作数据库的语言 MySQL是市场上第一个可用的开源数据库之一...SQL用于访问,更新和操作数据库中的数据 MySQL是一种RDBMS,它允许保持数据库中存在的数据 SQL是结构化查询语言 MySQL是一个使用MYSQL存储,检索,修改和管理数据库的RDBMS SQL

    4.2K20

    MySQL常用SQL语句大全

    的正则表达式:   1、Mysql支持REGEXP的正则表达式:     >SELECT * FROM tb_name WHERE name REGEXP ‘^[A-D]’ //找出以A-D 为开头的...九、MySQL的一些函数:   1、字符串链接——CONCAT()     >SELECT CONCAT(name,’=>’,score) FROM tb_name   2、数学函数:     ...  2、条件使用Having;   3、ORDER BY 排序:     ORDER BY DESC|ASC    =>按数据的降序和升序排列 十一、UNION规则——可以执行两个语句(可以去除重复行...;   1、支持触发器的语句有DELETE、INSERT、UPDATE,其他均不支持   2、创建触发器:     >CREATE TRIGGER trig AFTER INSERT ON ORDERS...FOR EACH ROW SELECT NEW.orser_name;     >INSERT语句,触发语句,返回一个值   3、删除触发器     >DROP TRIGGER trig; 十七

    3.1K20

    优化一个rownum=1的sql

    这是某个客户的BOSS系统中的一个top sql,SQL代码如下: SELECT t1.seq AS sequence ,t1.TemplateID AS templateId ,t1.parameter...<= : 1; 非常简单的一个SQL,每执行一次要消耗非常高的buffer gets,见下图: 执行计划是全表扫描: ----------------------------------------...针对这种sql,可以借助index的hint一招搞定,但是有个要求就是,表上这个index用到的字段必须有一个定义是not null,符合这样的索引随便找一个就行。 这样就不用走全表扫描了。...今天刚刚看到公司内一位老前辈写的一篇文章,讲到慎用hint。大方向是对的,但是,有些sql还是需要hint来进行优化,这个SQL就是个例子。...我之前的一些公众号文章也有一些SQL是需要hint来优化的。

    70110

    MySql的sql语句执行过程详述

    前言: 很多人都在使用mysql数据库,但是很少有人能够说出来整个sql语句的执行过程是怎样的,如果不了解执行过程的话,就很难进行sql语句的优化处理,也很难设计出来优良的数据库表结构。...这篇文章主要是讲解一下sql语句的执行过程。 sql语句的执行过程: 客户端、连接器、分析器、优化器、执行器、存储引擎几个阶段。 连接器的作用:管理链接、权限验证的处理。...查询缓存: 连接建立完毕之后,进行查询缓存的处理,执行sql语句会先到缓存中看看是不是刚刚执行了这条语句,之前执行过的语句及其结果就会以key-value对的形式直接存储在内存中的,key是查询的语句,...分析器: 分析器首先会进行词法分析,输入的是由多个字符串和空格组成的一条sql语句,mysql需要识别出来里面的字符串分别是什么,代表什么意思。...然后进行语法分析的处理,根据词法分析,根据词法分析的结果,语句分析器就会根据语法规则判断输入的这个sql语句是否满足mysql的语法。

    84140
    领券