mysql 存储过程教程

很文博客hinven.com 数据库评论70字数 1134阅读模式
广告也精彩

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

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

  1. CREATE PROCEDURE p_pageList
  2.   (
  3.   m_pageNo int ,
  4.   m_perPageCnt int ,
  5.   m_column varchar(1000) ,
  6.   m_table varchar(1000) ,
  7.   m_condition varchar(1000),
  8.   m_orderBy varchar(200) ,
  9.   out m_totalPageCnt int
  10.   )
  11.   BEGIN
  12.   SET @pageCnt = 1; -- 总记录数
  13.   SET @limitStart = (m_pageNo - 1)*m_perPageCnt;
  14.   SET @limitEnd = m_perPageCnt;
  15.   SET @sqlCnt = CONCAT('select count(1) into @pageCnt from ',m_table); -- 这条语句很关键,用来得到总数值
  16.   SET @sql = CONCAT('select ',m_column,' from ',m_table);
  17.   IF m_condition IS NOT NULL AND m_condition <> '' THEN
  18.   SET @sql = CONCAT(@sql,' where ',m_condition);
  19.   SET @sqlCnt = CONCAT(@sqlCnt,' where ',m_condition);
  20.   END IF;
  21.   IF m_orderBy IS NOT NULL AND m_orderBy <> '' THEN
  22.   SET @sql = CONCAT(@sql,' order by ',m_orderBy);
  23.   END IF;
  24.   SET @sql = CONCAT(@sql, ' limit ', @limitStart, ',', @limitEnd);
  25.   PREPARE s_cnt from @sqlCnt;
  26.   EXECUTE s_cnt;
  27.   DEALLOCATE PREPARE s_cnt;
  28.   SET m_totalPageCnt = @pageCnt;
  29.   PREPARE record from @sql;
  30.   EXECUTE record;
  31.   DEALLOCATE PREPARE record;
  32.   END

 文章源自很文博客https://www.hinven.com很文博客-https://www.hinven.com/52093.html

文章源自很文博客https://www.hinven.com很文博客-https://www.hinven.com/52093.html

工具:作品在线观看

女优:最新作品观看

中文:国语在线观看

weinxin
我的微信
扫一扫更精彩
大家的支持是我更新的动力!!!
 
广告也精彩
匿名

发表评论

匿名网友
:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:
确定

拖动滑块以完成验证