MySQL 教程 存储过程
2022-11-12 09:20:17
内容摘要
这篇文章主要为大家详细介绍了MySQL 教程 存储过程,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!不过在网上找了一些,发现都有一个特点&m
文章正文
这篇文章主要为大家详细介绍了MySQL 教程 存储过程,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
不过在网上找了一些,发现都有一个特点——就是不能传出总记录数,干脆自己研究吧。终于,算是搞出来了,效率可能不是很好,但是我也觉得不错了。贴代码吧直接:也算是对自己学习mysql的一个记录。代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | <code>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 </code> |
注:关于MySQL 教程 存储过程的内容就先介绍到这里,更多相关文章的可以留意
代码注释