我们在查询数据时,往往需要指定返回几行数据如现在有一个B/S架构的应用程序, 其每一页可能只显示30条记录此时为了提高显示的效率,一般就要求数据库一次只返回三 十条纪录等用户按下一页的时候,再从数据库中返回30条记录,以此类推这可以缩短数 据显示的时间当查询的基表比较大时,这个措施非常有效此时可以使用Limit关键字来 实现这个需求Limit子句可以被用于强制Select查询语句返回指定的记录数量通常情况下,Limit关键字可以接受一个或者两个数字参数需要注意的是,这个参数 必须是一个整数常量如果用户给定两个参数,则第一个参数表示第一个返回记录行的偏移 量,第二个参数则表示返回记录行的最大数据另外需要提醒的是,初始记录行的偏移量是 0,而不是1不少用户会在这里犯错误虽然使用了 Limit语句来限制返回的记录数,从而可以提高应用程序的工作效率 但是其也会给系统的性能带来一些负面影响如可能会导致全表扫描等等为此笔者给出一 些Limit关键字的优化的建议,以供大家参考建议一:灵活使用Limit 0子句根据Limit关键字的定义,如果参数为0的话,则其返回的是空记录这看起来好 像没有多少的意义。
其实不然在实际工作中,灵活使用这个0参数,能够给我们带来很大 的收获如现在数据库工程师想要确认一下某个查询语句的有效性,如果直接运行这个查询 语句,需要等待其返回的记录如果涉及的纪录数量比较多,或者运算逻辑比较复杂,那么 需要等到比较长的时间此时就可以在Select查询语句中,使用Limit 0子句只要查询语 句没有语法上的错误,这就可以让数据库快速的返回一个空集合从而帮助数据库设计人员 迅速的判断查询语句的有效性另外这个空集和中还会返回某个表的各个字段的数据类型 即通过这个Limit 0子句还可以查询某个表的表结构可见灵活应用Limir 0子句,确实能够给我们带来不小的收益不过需要注意的是, 在某些特定的场合下,这个子句可能不会奏效如通常情况下,在Monitor工作环境中不支 持这个Limit 0子句此时结果只会显示Empty Set,而不是我们所需要的结果建议二:Limit与Group By结合使用Group By关键字主要用来对数据进行分类汇总不过在分类汇总之前,往往需要对数据先进性排序而Limit语句用来指定显示的结果数量时,往往也需要涉及到纪录的分 类汇总与排序的问题如现在一个学校成绩管理系统中,需要对学生的总分进行排序。
即先 对学生各科成绩进行汇总,然后显示其排名为前50的纪录此时就需要同时用到Group By 子句和Limit子句其实从这个案例中我们也可以看出,这两个子句相互依赖的特性正是 因为这种特性(经常相互结合使用),为此结合Group By子句可以提高Limit的查询效率这主要是因为两者如果一起使用的话,Limit关键字将不会再重复计算任何不必要 的Group By的值换句话说,在某些情况下,Group By子句能够通过顺序来读取键或者 在键上做排序来解决分类汇总时的排序问题,然后再计算摘要直到关键字的值的改变为止 如此的话,两个子句所需要做的一些共同性的工作,只要做一次即可这就可以从另外一次 角度用来提高应用系统的性能相比先做一个视图对数据进行分类汇总的运算,再使用一个 查询语句来抽取特定数量的记录,效率就要高一点因为后者是将两个子句分开来使用,就 无法享受到结合使用所体现的优势建议三:使用SQL_calc_found_rows来提高子句的灵活性默认情况下,Limit子句返回用户所指定的记录行数只要数据库已经发送了用户 所需要的行数,则数据库系统会放弃剩余的查询即上面这个学生成绩的案例中,如果用户 只需要返回总分成绩排名前50的学生,贝I」数据库只返回50条记录,然后终止查询作业。
但是在某些特定的情况下,用户可能仍然需要继续后续的查询呢?如用户出了查询 某些特定的记录,还需要知道总的记录数量,此时该如何处理?如现在用户需要知道排名前5 0的学生信息,同时需要知道总分在500分以上的总人数此时单独使用Limit子句可能无法 满足用户的需求,因为其只关心前面50条记录如果要实现这个需求的话,往往需要结合S QL_calc_found_rows 关键字这个关键字的主要用途就是能够在查询时为数据库管理员事先准备好符合Where 条件语句的记录数目然后用户只要在随后执行一条Select Found_ROWS语句之后,就可 以获得符合条件的记录总数不过需要注意的是,使用这个关键字会带来一定的副作用即 带有这个关键字的查询语句,是无法使用数据缓存的故在某些情况下会降低数据查询的性 能故一般情况下,这个关键字只用于Where条件语句比较复杂的情况当然这只是一个 出于性能考虑的建议,而并不是技术上的限制即即使Where条件语句不复杂,也可以使 用这个关键字,不会出现语法上的错误只是其在性能上并不是很理想建议四:与Distinct关键字共同使用时的特殊现象Distinct关键字主要用来过滤重复的记录。
而Limit关键字则主要用来指定记录所 返回的行数如果这两个关键字共同使用时,会出现什么样的情况呢?如果从字面意思去理 解,数据库会返回指定的不重复的记录数如Limit的参数为50,则数据库返回50条不重复 的记录数然后后续的查询就会停止如果查询的记录中有重复记录,则数据库查询的实际 数量往往要比Limit关键字所指定的数量要多在实际工作中,这条语句的作用还是很大的如现在有一张员工考勤信息的表格 现在数据库管理员需要统计缺勤次数排名前20的员工人数此时为了防止有重复的记录,就 可以在查询语句中加一个Distinct关键字,用来过滤重复的记录数从而可以避免采用多个 查询语句来完成这个需求建议五:Limit与索引之间的关系如果数据库管理员决定使用Limit子句来指定需要显示的记录数,那么最好能够最 大限度的使用索引,以避免全表扫描,提高工作效率即当数据库选择做完整的表扫描时, 可以在某些情况下使用索引如现在数据库管理员决定将Limit子句与Order BY子句一起使用数据库一旦找 到了排序结果的第一个RowCount行,则系统将会结束排序,而并不会对整个表进行排序 如果单独使用Order By子句的话,则会对整个表进行排序。
虽然如此,但是排序必定要浪 费一定的时间此时数据库管理员如果决定使用索引,则可以在很大程度上提高这个查询的 效率对于这个内容,笔者要强调一个问题如果必须要进行文件排序,则必须选择所有 匹配查询,并且在确定已经找到第一个行之前,必须对他们的大部分内容进行了排序特别 需要强调的是,在任何情况下,一旦找到了行,则就不需要再排序结果的其他部分,数据库 会自动结束排序可见Limit子句其本质的功能是限制用户的纪录数量但是其还有很多别的用途 如快速判断查询语句的有效性、计算表所需要的空间等等不过其也有一定的副作用,可能 会带系统的运行带来一些负面的影响此时最好能够采取一些措施来提高系统运行的性能。