MySQL分页查询通用存储过程的解剖

数据库 MySQL
此文章主要向大家阐述的是正确实现MySQL分页查询通用存储过程,如果你对其实际操作有不清楚的地方,你就可以通过下面的文章对其进行了解。

以下的文章主要向大家描述的是MySQL分页查询通用存储过程的实际应用,我在一个信誉度很好的网站找到一个关于MySQL分页查询通用存储过程的实际应用资料,拿出来供大家分享,望大家能有所收获。

前段时间没有给出SQLServer转到MySQL(和PHP搭配之***组合)的通用存储过程,本着共享的精神,为大家奉献这段MySQL分页查询通用存储过程,假设所用数据库为guestbook:

  1. use guestbook;  
  2. delimiter $$  
  3. drop procedure if exists prc_page_result $$  
  4. create procedure prc_page_result (  
  5. in currpage int,  
  6. in columns varchar(500),  
  7. in tablename varchar(500),  
  8. in sCondition varchar(500),  
  9. in order_field varchar(100),  
  10. in asc_field int,  
  11. in Prima(最完善的虚拟主机管理系统)ry_field varchar(100),  
  12. in pagesize int  
  13. )  
  14. begin  
  15. declare sTemp varchar(1000);  
  16. declare sSql varchar(4000);  
  17. declare sOrder varchar(1000);  
  18. if asc_field = 1 then  
  19. set sOrder = concat(' order by ', order_field, ' desc ');  
  20. set sTemp = '<(select min';  
  21. else  
  22. set sOrder = concat(' order by ', order_field, ' asc ');  
  23. set sTemp = '>(select max';  
  24. end if;  
  25. if currpage = 1 then  
  26. if sCondition <> '' then  
  27. set sSql = concat('select ', columns, ' from ', tablename, ' where ');  
  28. set sSql = concat(sSql, sCondition, sOrder, ' limit ?');  
  29. else  
  30. set sSql = concat('select ', columns, ' from ', tablename, sOrder, ' limit ?');  
  31. end if;  
  32. else  
  33. if sCondition <> '' then  
  34. set sSql = concat('select ', columns, ' from ', tablename);  
  35. set sSql = concat(sSql, ' where ', sCondition, ' and ', Prima(最完善的虚拟主机管理系统)ry_field, sTemp);  
  36. set sSql = concat(sSql, '(', Prima(最完善的虚拟主机管理系统)ry_field, ')', ' from (select ');  
  37. set sSql = concat(sSql, ' ', Prima(最完善的虚拟主机管理系统)ry_field, ' from ', tablename, sOrder);  
  38. set sSql = concat(sSql, ' limit ', (currpage-1)*pagesize, ') as tabtemp)', sOrder);  
  39. set sSql = concat(sSql, ' limit ?');  
  40. else  
  41. set sSql = concat('select ', columns, ' from ', tablename);  
  42. set sSql = concat(sSql, ' where ', Prima(最完善的虚拟主机管理系统)ry_field, sTemp);  
  43. set sSql = concat(sSql, '(', Prima(最完善的虚拟主机管理系统)ry_field, ')', ' from (select ');  
  44. set sSql = concat(sSql, ' ', Prima(最完善的虚拟主机管理系统)ry_field, ' from ', tablename, sOrder);  
  45. set sSql = concat(sSql, ' limit ', (currpage-1)*pagesize, ') as tabtemp)', sOrder);  
  46. set sSql = concat(sSql, ' limit ?');  
  47. end if;  
  48. end if;  
  49. set @iPageSize = pagesize;  
  50. set @sQuery = sSql;  
  51. prepare stmt from @sQuery;  
  52. execute stmt using @iPageSize;  
  53. end;  
  54. $$  
  55. delimiter;  

可以存储为数据库脚本,然后用命令导入:

MySQL(和PHP搭配之***组合) -u root -p < pageResult.sql;

调用:

  1. call prc_page_result(1, "*", "Tablename", "", "columnname", 1, "PKID", 25); 

上述的相关内容就是对MySQL分页查询通用存储过程的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. 编译MySQL代码在Windows平台上
  2. MySQL ROOT密码的修改指南
  3. MySQL 乱码处理的破解方案
  4. 使用PHP+MySQL来对图书管理系统进行构建
  5. 3G与IPTV是发展大方向

 

责任编辑:佚名 来源: 互联网
相关推荐

2010-06-11 14:41:20

MySQL分页查询

2010-05-13 15:54:56

MySQL分页查询

2011-03-24 13:31:35

2分法存储过程分页

2010-04-27 14:44:31

Oracle存储过程

2010-04-12 09:26:52

Oracle查询分页

2015-08-19 14:18:56

SQLasp.net后台调用

2011-03-24 13:38:47

SQL Server 存储分页

2010-11-29 09:12:46

sybase分页存储过

2010-11-29 09:45:30

Sybase分页

2010-09-13 13:12:28

sqlserver分页

2010-04-30 09:34:24

Oracle多条件查询

2010-10-26 14:50:11

oracle存储过程

2010-06-04 14:18:10

MySQL 分页存储过

2011-10-10 16:44:37

分页数据库

2011-03-28 10:46:36

sql server存储分页

2010-09-14 10:47:45

sql server存

2010-11-25 14:21:16

MySQL查询分页

2010-06-30 14:36:49

SQL Server

2010-06-18 10:34:38

SQL Server

2010-05-06 14:01:12

Oracle分页存储过
点赞
收藏

51CTO技术栈公众号