自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何通用存儲過程來對MySQL分頁查詢進行操作

數(shù)據(jù)庫 MySQL
我們今天主要描述的是通用存儲過程來對MySQL分頁查詢進行正確的操作,以下就是文章的具體內(nèi)容的詳細介紹,望你瀏覽之后會有所收獲。

以下的文章主要描述的是通用存儲過程來對MySQL分頁查詢進行正確的操作,你如果對MySQL分頁查詢進行正確的操作有興趣的話你就可以點擊以下的文章進行觀看了。望你瀏覽之后能有所收獲。

前段時間沒有給出SQLServer轉(zhuǎn)到MySQL(和PHP搭配之***組合)的通用存儲過程,本著共享的精神,為大家奉獻這段MySQL分頁查詢通用存儲過程,假設(shè)所用數(shù)據(jù)庫為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(最完善的虛擬主機管理系統(tǒng))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.  
  19. if asc_field = 1 then  
  20. set sOrder = concat(' order by ', order_field, ' desc ');  
  21. set sTemp = '<(select min';  
  22. else  
  23. set sOrder = concat(' order by ', order_field, ' asc ');  
  24. set sTemp = '>(select max';  
  25. end if;  
  26.  
  27. if currpage = 1 then  
  28. if sCondition <> '' then  
  29. set sSql = concat('select ', columns, ' from ', tablename, ' where ');  
  30. set sSql = concat(sSql, sCondition, sOrder, ' limit ?');  
  31. else  
  32. set sSql = concat('select ', columns, ' from ', tablename, sOrder, ' limit ?');  
  33. end if;  
  34. else  
  35. if sCondition <> '' then  
  36. set sSql = concat('select ', columns, ' from ', tablename);  
  37. set sSql = concat(sSql, ' where ', sCondition, ' and ', Prima(最完善的虛擬主機管理系統(tǒng))ry_field, sTemp);  
  38. set sSql = concat(sSql, '(', Prima(最完善的虛擬主機管理系統(tǒng))ry_field, ')', ' from (select ');  
  39. set sSql = concat(sSql, ' ', Prima(最完善的虛擬主機管理系統(tǒng))ry_field, ' from ', tablename, sOrder);  
  40. set sSql = concat(sSql, ' limit ', (currpage-1)*pagesize, ') as tabtemp)', sOrder);  
  41. set sSql = concat(sSql, ' limit ?');  
  42. else  
  43. set sSql = concat('select ', columns, ' from ', tablename);  
  44. set sSql = concat(sSql, ' where ', Prima(最完善的虛擬主機管理系統(tǒng))ry_field, sTemp);  
  45. set sSql = concat(sSql, '(', Prima(最完善的虛擬主機管理系統(tǒng))ry_field, ')', ' from (select ');  
  46. set sSql = concat(sSql, ' ', Prima(最完善的虛擬主機管理系統(tǒng))ry_field, ' from ', tablename, sOrder);  
  47. set sSql = concat(sSql, ' limit ', (currpage-1)*pagesize, ') as tabtemp)', sOrder);  
  48. set sSql = concat(sSql, ' limit ?');  
  49. end if;  
  50. end if;  
  51. set @iPageSize = pagesize;  
  52. set @sQuery = sSql;  
  53. prepare stmt from @sQuery;  
  54. execute stmt using @iPageSize;  
  55. end;  
  56. $$  
  57. delimiter; 

可以存儲為數(shù)據(jù)庫腳本,然后用命令導入:

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

調(diào)用:

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

以上的相關(guān)內(nèi)容就是對MySQL分頁查詢通用存儲過程的介紹,望你能有所收獲。

【編輯推薦】

  1. MySQL 5.0新特性教程之存儲過程
  2. 實現(xiàn)MySQL數(shù)據(jù)庫引擎的快速指導
  3. MySQL初學者的必備3要素
  4. MySQL維護與實際應用的設(shè)計筆記簡介
  5. 實現(xiàn)MySQL雙機熱備的實際操作步驟
責任編輯:佚名 來源: 博客園
相關(guān)推薦

2010-06-10 12:37:27

MySQL分頁查詢

2010-06-11 14:41:20

MySQL分頁查詢

2010-05-19 14:13:12

MySQL存儲過程

2010-06-04 13:50:24

MySQL存儲過程

2010-07-08 17:15:04

SQL Server存

2011-03-24 13:31:35

2分法存儲過程分頁

2010-05-06 14:11:55

Oracle多條件查詢

2010-06-04 14:18:10

MySQL 分頁存儲過

2015-08-19 14:18:56

SQLasp.net后臺調(diào)用

2010-04-12 09:26:52

Oracle查詢分頁

2010-04-16 10:42:10

Oracle存儲過程

2010-09-13 13:12:28

sqlserver分頁

2010-11-29 09:45:30

Sybase分頁

2010-04-30 09:34:24

Oracle多條件查詢

2010-09-03 15:08:03

SQLselect語句

2010-10-12 10:48:02

mysql存儲過程

2010-04-30 08:47:22

Oracle分頁存儲

2010-04-16 11:03:02

Oracle存儲過程

2019-09-11 10:40:49

MySQL大分頁查詢數(shù)據(jù)庫

2010-06-18 10:34:38

SQL Server
點贊
收藏

51CTO技術(shù)棧公眾號