请选择 进入手机版 | 继续访问电脑版

我爱自学

 找回密码
 会员注册

QQ登录

只需一步,快速开始

mysql limit高级用法示例

mysql limit高级用法示例

        mysql limit效率:

        select `id`,`title`,`describle`,`created` from myvbga_table where click = xxx limit offset, limit;  //总结:如果没有blob/text字段,单行记录比较小,可以把 limit 设大点,会加快速度。

        limit offset值比较小:

            select `id`,`title`,`describle`,`created` from vbga_table limit 10,10  //多次运行,时间保持在0.0004-0.0005之间
            Select `id`,`title`,`describle`,`created` From vbga_table Where click >=(Select click From vbga_table Order By click limit 10,1) limit 10  //多次运行,时间保持在0.0005-0.0006之间,主要是0.0006

        limit offset值比较大:

            select `id`,`title`,`describle`,`created` from vbga_table limit 10000,10  //多次运行,时间保持在0.0187左右
            Select `id`,`title`,`describle`,`created` From vbga_table Where click >=(Select click From vbga_table Order By click limit 10000,1) limit 10 //多次运行,时间保持在0.0061左右,只有前者的1/3。可以预计offset越大,后者越优。

        Mysql的limit用法:

            LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数
            SELECT `id`,`title`,`describle`,`created` FROM vbga_table LIMIT [offset,] rows | rows OFFSET offset  

            mysql> SELECT `id`,`title`,`describle`,`created` FROM vbga_table LIMIT 5,10; // 检索记录行 6-15 //为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1:
            mysql> SELECT `id`,`title`,`describle`,`created` FROM vbga_table LIMIT 95,-1; // 检索记录行 96-last. //如果只给定一个参数,它表示返回最大的记录行数目:
            mysql> SELECT `id`,`title`,`describle`,`created` FROM vbga_table LIMIT 5; //检索前 5 个记录行 //换句话说,LIMIT n 等价于 LIMIT 0,n。

        mysql limit 子查询用法示例:
            select `id`,`title`,`describle`,`created` from vbga_table where id in (select t.id from (select `id`,`title`,`describle`,`created` from vbga_table limit 10)as t)

        mysql limit offset用法:

            SELECT keyword FROM `zjoe_table` WHERE advertiserid='59' order by keyword LIMIT 2 OFFSET 1; //比如这个SQL ,limit后面跟的是2条数据,offset后面是从第1条开始读取
            ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
            SELECT `keyword` FROM `zjoe_table` WHERE advertiserid='59' ORDER BY keyword LIMIT 2 ,1; //而这个SQL,limit后面是从第2条开始读,读取1条信息。

        mysql存储过程中limit变量用法

            CREATE PROCEDURE Getble_table(_id int,_limit int)
            BEGIN
            PREPARE s1 FROM 'SELECT `id`,`title`,`describle`,`created` FROM ble_table WHERE Cityid=? ORDER BY sendtime DESC LIMIT ?';
            set @a=_id;
            set @b=_limit;
            EXECUTE s1 USING @a,@b;
            DEALLOCATE PREPARE s1;
            END;

        注意:需要传参数的地方一定要用"?"号,第一个FRom后面的语句要用''括起。


点击阅读更多内容!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

手机版|小黑屋|我爱自学 ( 蜀ICP备19015358号-3 )

GMT+8, 2022-12-6 01:27 , Processed in 0.042743 second(s), 24 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

本站部分资源来源网络,仅供学习与交流使用,如果侵犯到您的权益,请及时联系本站(569705694@qq.com)删除该资源。

X
淘宝聚划算
快速回复 返回顶部 返回列表