服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - mysql 教程 存储过程

mysql 教程 存储过程

2019-10-29 17:17mysql教程网 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 

延伸 · 阅读

精彩推荐
  • Mysql详解MySQL中的分组查询与连接查询语句

    详解MySQL中的分组查询与连接查询语句

    这篇文章主要介绍了MySQL中的分组查询与连接查询语句,同时还介绍了一些统计函数的用法,需要的朋友可以参考下 ...

    GALAXY_ZMY5442020-06-03
  • MysqlMySQL锁的知识点总结

    MySQL锁的知识点总结

    在本篇文章里小编给大家整理了关于MySQL锁的知识点总结以及实例内容,需要的朋友们学习下。...

    别人放弃我坚持吖4362020-12-14
  • MysqlMySQL数据库varchar的限制规则说明

    MySQL数据库varchar的限制规则说明

    本文我们主要介绍了MySQL数据库中varchar的限制规则,并以一个实际的例子对限制规则进行了说明,希望能够对您有所帮助。 ...

    mysql技术网4192019-11-23
  • Mysql浅谈mysql 树形结构表设计与优化

    浅谈mysql 树形结构表设计与优化

    在诸多的管理类,办公类等系统中,树形结构展示随处可见,本文主要介绍了mysql 树形结构表设计与优化,具有一定的参考价值,感兴趣的小伙伴们可以参...

    小码农叔叔5242021-11-16
  • Mysql解决MySQl查询不区分大小写的方法讲解

    解决MySQl查询不区分大小写的方法讲解

    今天小编就为大家分享一篇关于解决MySQl查询不区分大小写的方法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起...

    Veir_dev5592019-06-25
  • MysqlMySQL 数据备份与还原的示例代码

    MySQL 数据备份与还原的示例代码

    这篇文章主要介绍了MySQL 数据备份与还原的相关知识,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...

    逆心2972019-06-23
  • Mysqlmysql 不能插入中文问题

    mysql 不能插入中文问题

    当向mysql5.5插入中文时,会出现类似错误 ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column ...

    MYSQL教程网5722019-11-25
  • MysqlERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event(): read error, data_len: 438, event_type: 2 ...

    MYSQL教程网6412020-03-13