程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 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. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved