最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

如何通用存储过程来对MySQL分页查询进行操作

来源:动视网 责编:小采 时间:2020-11-09 14:13:12
文档

如何通用存储过程来对MySQL分页查询进行操作

如何通用存储过程来对MySQL分页查询进行操作:以下的文章主要描述的是通用存储过程来对MySQL分页查询进行正确的操作,你如果对MySQL分页查询进行正确的操作有兴趣的话你就可以点击以下的文章进行观看了。望你浏览之后能有所收获。 前段时间没有给出SQLServer转到MySQL(和PHP搭配之最佳组合)的通用存储过
推荐度:
导读如何通用存储过程来对MySQL分页查询进行操作:以下的文章主要描述的是通用存储过程来对MySQL分页查询进行正确的操作,你如果对MySQL分页查询进行正确的操作有兴趣的话你就可以点击以下的文章进行观看了。望你浏览之后能有所收获。 前段时间没有给出SQLServer转到MySQL(和PHP搭配之最佳组合)的通用存储过


以下的文章主要描述的是通用存储过程来对MySQL分页查询进行正确的操作,你如果对MySQL分页查询进行正确的操作有兴趣的话你就可以点击以下的文章进行观看了。望你浏览之后能有所收获。 前段时间没有给出SQLServer转到MySQL(和PHP搭配之最佳组合)的通用存储过

以下的文章主要描述的是通用存储过程来对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分页查询通用存储过程的介绍,望你能有所收获。

文档

如何通用存储过程来对MySQL分页查询进行操作

如何通用存储过程来对MySQL分页查询进行操作:以下的文章主要描述的是通用存储过程来对MySQL分页查询进行正确的操作,你如果对MySQL分页查询进行正确的操作有兴趣的话你就可以点击以下的文章进行观看了。望你浏览之后能有所收获。 前段时间没有给出SQLServer转到MySQL(和PHP搭配之最佳组合)的通用存储过
推荐度:
标签: 查询 操作 过程
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top