php执行多个存储过程的方法【基于thinkPHP】


Posted in PHP onNovember 08, 2016

本文实例讲述了php执行多个存储过程的方法。分享给大家供大家参考,具体如下:

从以前的使用原生代码来看,只需要将结果集关闭即可,即

$this -> queryID -> close();

使用mysqli方式,修改DbMysqli.class.php,将query函数改为:

public function query($str) {
    $this -> initConnect(false);
    if (!$this -> _linkID) {
      return false;
    }
    $this -> queryStr = $str;
    //释放前次的查询结果
    if ($this -> queryID)
      $this -> free();
    N('db_query', 1);
    // 记录开始执行时间
    G('queryStartTime');
    $this -> queryID = $this -> _linkID -> query($str);
    // 对存储过程改进
    $ret = array();
    $this -> debug();
    if (false === $this -> queryID) {
      $this -> error();
      return false;
    } else {
      $this -> numRows = $this -> queryID -> num_rows;
      $this -> numCols = $this -> queryID -> field_count;
      $ret = $this -> getAll();
    }
    //主要将这段移动了一下,关闭结果集
    if ($this -> _linkID -> more_results()) {
      while (($res = $this -> _linkID -> next_result()) != NULL) {
        $this -> queryID -> close();
      }
    }
    return $ret ;
}

下面就可以调用多个存储过程,或许执行其他SQL操作,可以直接使用M函数

在使用thinkphp的时候发现执行多个存储过程只能执行第一个,看了一下源码Driver/Db/DbMysql.class,已经对存储过程进行了一定处理,但是不知道为什么运行不了。

用原生代码解决了问题(下面是部分代码):

$db = new mysqli(C("DB_HOST"), C("DB_USER"), C("DB_PWD"), C("DB_NAME"));
if (mysqli_connect_errno())
throw_exception(mysqli_connect_error());
$t2 = microtime(true);
echo "数据库连接用时:" . (($t2 - $t1)) . "s <br />";
$arr = array();
// 1st Query
$procedure = "call p1()";
$result = $db->query($procedure);
if ($result) {
// Cycle through results
while ($row = $result->fetch_object()) {
//添加到对象数组
$arr[] = $row;
}
// 这里是最重要的,需要将游标移动下一个结果集
$result->close();
$db->next_result();
}
$procedure = "call p2()";
$result = $db->query($procedure);
if ($result) {
// Cycle through results
while ($row = $result->fetch_object()) {
//添加到对象数组
$arr[] = $row;
}
// 这里是最重要的,需要将游标移动下一个结果集
$result->close();
$db->next_result();
}

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

PHP 相关文章推荐
PHP iconv 解决utf-8和gb2312编码转换问题
Apr 12 PHP
PHP GD 图像处理组件的常用函数总结
Apr 28 PHP
Yii2使用小技巧之通过 Composer 添加 FontAwesome 字体资源
Jun 22 PHP
php中file_exists函数使用详解
May 08 PHP
php正则表达式验证(邮件地址、Url地址、电话号码、邮政编码)
Mar 14 PHP
php生成txt文件实例代码介绍
Apr 28 PHP
3种方法轻松处理php开发中emoji表情的问题
Jul 18 PHP
基于ThinkPHP实现的日历功能实例详解
Apr 15 PHP
PHP-X系列教程之内置函数的使用示例
Oct 16 PHP
PHP预定义超全局数组变量小结
Aug 20 PHP
针对PHP开发安全问题的相关总结
Mar 22 PHP
Laravel多域名下字段验证的方法
Apr 04 PHP
php实现的http请求封装示例
Nov 08 #PHP
PHP实现原生态图片上传封装类方法
Nov 08 #PHP
php使用FFmpeg接口获取视频的播放时长、码率、缩略图以及创建时间
Nov 07 #PHP
Yii2框架BootStrap样式的深入理解
Nov 07 #PHP
php 时间time与日期date之间的使用详解及区别
Nov 07 #PHP
php 微信公众平台开发模式实现多客服的实例代码
Nov 07 #PHP
深入了解PHP中的Array数组和foreach
Nov 06 #PHP
You might like
PHP URL地址获取函数代码(端口等) 推荐
2010/05/15 PHP
php专用数组排序类ArraySortUtil用法实例
2015/04/03 PHP
使用PHP进行微信公众平台开发的示例
2015/08/21 PHP
PHP使用redis消息队列发布微博的方法示例
2017/06/22 PHP
PHP正则表达式函数preg_replace用法实例分析
2020/06/04 PHP
如何判断图片地址是否失效
2007/02/02 Javascript
Mootools 1.2教程 定时器和哈希简介
2009/09/15 Javascript
JSON 编辑器实现代码
2009/12/06 Javascript
将查询条件的input、select清空
2014/01/14 Javascript
jQuery点击其他地方时菜单消失的实现方法
2016/04/22 Javascript
JS短信验证码倒计时功能的实现(没有验证码,只有倒计时)
2016/10/27 Javascript
Vue实现双向绑定的方法
2016/12/22 Javascript
jQuery阻止移动端遮罩层后页面滚动
2017/03/15 Javascript
原生javascript实现分页效果
2017/04/21 Javascript
Angular 数据请求的实现方法
2018/05/07 Javascript
Angular(5.2-&gt;6.1)升级小结
2018/12/27 Javascript
js定时器出现第一次延迟的原因及解决方法
2021/01/04 Javascript
Python函数式编程指南(三):迭代器详解
2015/06/24 Python
浅析Python中的getattr(),setattr(),delattr(),hasattr()
2016/06/14 Python
python抓取并保存html页面时乱码问题的解决方法
2016/07/01 Python
Python3.4编程实现简单抓取爬虫功能示例
2017/09/14 Python
利用Python写一个爬妹子的爬虫
2018/06/08 Python
Python Matplotlib 基于networkx画关系网络图
2019/07/10 Python
pycharm中显示CSS提示的知识点总结
2019/07/29 Python
解决Django中调用keras的模型出现的问题
2019/08/07 Python
python文字和unicode/ascll相互转换函数及简单加密解密实现代码
2019/08/12 Python
python脚本执行CMD命令并返回结果的例子
2019/08/14 Python
分享PyCharm的几个使用技巧
2019/11/10 Python
HTML5 拖放功能实现代码
2016/07/14 HTML / CSS
Linux如何修改文件和文件夹的权限
2013/09/05 面试题
放飞中国梦演讲稿
2014/04/23 职场文书
《山谷中的谜底》教学反思
2014/04/26 职场文书
迁户口计划生育证明
2014/10/19 职场文书
颐和园的导游词
2015/01/30 职场文书
2015年电工工作总结
2015/04/10 职场文书
源码安装apache脚本部署过程详解
2022/09/23 Servers