mysql的高效存取过程分页
来源:互联网 发布:找常熟淘宝仓库工作 编辑:程序博客网 时间:2024/04/25 23:05
10w以上数据的效率比普通分页 快4-5倍
PROCEDURE p_pageList (m_pageNo int , m_perPageCnt int , m_indexcolumn varchar(100), m_column varchar(1000) , m_table varchar(1000) , m_condition varchar(1000), m_orderBy varchar(200) , inout m_totalPageCnt int)
BEGIN
IF m_totalPageCnt >=1 THEN
SET @sqlCnt = CONCAT('select count(1) into @pageCnt from ',m_table); -- è¿æ¡è¯å¥å¾å
³é®ï¼ç¨æ¥å¾å°æ»æ°å¼
IF m_condition IS NOT NULL AND m_condition <> '' THEN
SET @sqlCnt = CONCAT(@sqlCnt,' where ',m_condition);
END IF;
PREPARE s_cnt from @sqlCnt;
EXECUTE s_cnt;
DEALLOCATE PREPARE s_cnt;
SET m_totalPageCnt = @pageCnt;
else
SET @pageCnt = 1; -- æ»è®°å½æ°
SET @limitStart = (m_pageNo - 1)*m_perPageCnt;
SET @limitEnd = m_perPageCnt;
SET @sql = CONCAT('select ',m_column,' from ',m_table); -- 主æ¥è¯¢
SET @wsql = CONCAT('select ',m_indexcolumn,' from ',m_table); -- åæ¥è¯¢
IF m_condition IS NOT NULL AND m_condition <> '' THEN
SET @sql = CONCAT(@sql,' where ',m_condition);
SET @wsql = CONCAT(@wsql,' where ',m_condition);
END IF;
IF @limitStart<1000 THEN
IF m_orderBy IS NOT NULL AND m_orderBy <> '' THEN
SET @sql = CONCAT(@sql,' order by ',m_orderBy);
END IF;
SET @sql = CONCAT(@sql, ' limit ', @limitStart, ',', @limitEnd);
Else
IF m_orderBy IS NOT NULL AND m_orderBy <> '' THEN
SET @wsql = CONCAT(@wsql,' order by ',m_orderBy);
IF m_condition IS NOT NULL AND m_condition <> '' THEN
SET @sql = CONCAT(@sql,' and ', m_indexcolumn ,'>=(',@wsql, ' limit ', @limitStart,',1) ' ,' order by ', m_orderBy, ' limit ',@limitEnd);
else
SET @sql = CONCAT(@sql,' where ', m_indexcolumn ,'>=(',@wsql, ' limit ', @limitStart,',1) ' , ' order by ',m_orderBy, ' limit ',@limitEnd);
END IF;
Else
IF m_condition IS NOT NULL AND m_condition <> '' THEN
SET @sql = CONCAT(@sql,' and ', m_indexcolumn ,'>=(',@wsql, ' limit ', @limitStart,',1) ' , ' limit ',@limitEnd);
else
SET @sql = CONCAT(@sql,' where ', m_indexcolumn ,'>=(',@wsql, ' limit ', @limitStart,',1) ' , ' limit ',@limitEnd);
END IF;
END IF;
END IF;
PREPARE record from @sql;
EXECUTE record;
DEALLOCATE PREPARE record;
/*
select @sql;
*/
END IF;
END
- mysql的高效存取过程分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的MySQL分页
- 高效的分页存储过程
- mysql 存储过程-高效分页方法
- SQL 分页存取过程
- 构建高效的MySQL分页
- 推荐两款免费的文本编辑器
- 路由器_内网端口映射
- Gfx_BeginScene
- Ubuntu查找源的方法(通杀)
- UltraWebGrid的自动序号
- mysql的高效存取过程分页
- 请将类模板的声明和实现都写在.h文件中
- PE燃气管
- 用C#实现屏幕锁定
- Drools5学习笔记1-最常用API
- js改变选择的行颜色
- shell script里面判断某个程序是否还在运行
- 开发人员一定要加入收藏夹的网站
- 物联网概念下的B2C电子商务平台“开放”浅析