mysql存储过程的教程

来源:爱站网时间:2019-05-02编辑:网友分享
mysql是开源的关系型数据库,因此选择很多人为了方便都在使用mysql数据库,而存储过程是为了完成特定功能的一组SQL语句集,现在我们就去看看mysql存储过程的教程。

mysql是开源的关系型数据库,因此选择很多人为了方便都在使用mysql数据库,而存储过程是为了完成特定功能的一组SQL语句集,现在我们就去看看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

       看了以上关于mysql存储过程的教程的内容后你是否明白了呢?如果你还想了解更多相关内容就请关注爱站技术频道吧。

上一篇:如何恢复MySQL的密码

下一篇:详解绿色版mysql的安装配置

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载