zoukankan      html  css  js  c++  java
  • mysql的分页存储过程,能够传出总记录数

    最近用mysql + asp.net来写网站,既然mysql已经支持存储过程了,那么像分页这么常用的东西,当然要用存储过程啦

      不过在网上找了一些,发现都有一个特点——就是不能传出总记录数,干脆自己研究吧。终于,算是搞出来了,效率可能不是很好,但是我也觉得不错了。贴代码吧直接:也算是对自己学习mysql的一个记录。


      CREATE PROCEDURE p_pageList 
      ( 
      m_pageNo int , 
      m_perPageCnt int , 
      m_column varchar(1000) , 
      m_table varchar(1000) , 
      m_condition varchar(1000), 
      m_orderBy varchar(200) , 
      out m_totalPageCnt int 
      ) 
      BEGIN 
      SET @pageCnt = 1; -- 总记录数 
      SET @limitStart = (m_pageNo - 1)*m_perPageCnt; 
      SET @limitEnd = m_perPageCnt; 
      SET @sqlCnt = CONCAT('select count(1) into @pageCnt from ',m_table); -- 这条语句很关键,用来得到总数值 
      SET @sql = CONCAT('select ',m_column,' from ',m_table); 
      IF m_condition IS NOT NULL AND m_condition <> '' THEN 
      SET @sql = CONCAT(@sql,' where ',m_condition); 
      SET @sqlCnt = CONCAT(@sqlCnt,' where ',m_condition); 
      END IF; 
      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); 
      PREPARE s_cnt from @sqlCnt; 
      EXECUTE s_cnt; 
      DEALLOCATE PREPARE s_cnt; 
      SET m_totalPageCnt = @pageCnt; 
      PREPARE record from @sql; 
      EXECUTE record; 
      DEALLOCATE PREPARE record; 
      END
  • 相关阅读:
    Linux mysql 远程访问
    Linux下高并发socket最大连接数所受的各种限制
    Linux之gunzip命令
    不停在终端中报log
    FIO测试
    yum是什么?(linux命令)
    ubuntu grub 登录
    百度网盘命令行方式,解决ubuntu16.04百度网盘无法运行的问题
    excel使用经验汇总
    ubuntu 安装 ipfs 经验
  • 原文地址:https://www.cnblogs.com/lp-zy/p/4362716.html
Copyright © 2011-2022 走看看