mysql 教程 存储过程

lwb6102628

lwb6102628

2016-02-19 09:56

有了下面这个mysql 教程 存储过程教程,不懂mysql 教程 存储过程的也能装懂了,赶紧get起来装逼一下吧!
不过在网上找了一些,发现都有一个特点——就是不能传出总记录数,干脆自己研究吧。终于,算是搞出来了,效率可能不是很好,但是我也觉得不错了。贴代码吧直接:也算是对自己学习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
展开更多 50%)
分享

猜你喜欢

mysql 教程 存储过程

编程语言 网络编程
mysql 教程 存储过程

mysql 存储过程的问题

编程语言 网络编程
mysql 存储过程的问题

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

mysql 动态执行存储过程语句

编程语言 网络编程
mysql 动态执行存储过程语句

mysql 树形结构查询(存储过程)

编程语言 网络编程
mysql 树形结构查询(存储过程)

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

MySQL5新特点(存储过程)

编程语言 网络编程
MySQL5新特点(存储过程)

mysql存储过程写法—动态参数运用

编程语言 网络编程
mysql存储过程写法—动态参数运用

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

基于Manifest.xml中不要出现重复的uses permission的说明

基于Manifest.xml中不要出现重复的uses permission的说明

转一个日期输入控件支持FF

转一个日期输入控件支持FF
下拉加载更多内容 ↓