博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php mysql 数组存储过程_php调用MySQL存储过程的方法集合(推荐)
阅读量:5742 次
发布时间:2019-06-18

本文共 1892 字,大约阅读时间需要 6 分钟。

本篇文章是对php调用MySQL存储过程的方法进行了集合与汇总,需要的朋友参考下

类型一:调用带输入、输出类型参数的方法

$returnValue = '';

try {

mysql_query ( "set @Return" );

$spname = 'P__Test_GetInfo1';

mysql_query ( "call $spname(@Return, '{$userId}', '{$pwd}')" ) or die ( "[$spname]Query failed:" . mysql_error () );

$result_return = mysql_query ( "select @Return" );

$row_return = mysql_fetch_row ( $result_return );

$returnValue = $row_return [0];

} catch ( Exception $e ) {

echo $e;

}

echo $returnValue; //输出来自存储过程中输出的变量

类型二:调用带多个输出类型和多个输入类型参数的方法

$userId = 0;

try{

mysql_query("set @Message");

mysql_query("set @Id");

mysql_query("call P__Test_Login(@Message, @Id, '{$userId}', '{$pwd}')", $conn) or die("Query failed:".mysql_error());

$result_mess = mysql_query("select @Message");

$result_uid = mysql_query("select @Id");

$row_mess = mysql_fetch_row($result_mess);

$row_uid = mysql_fetch_row($result_uid);

$Proc_Error = $row_mess[0];

$uId = $row_uid[0];

}

catch( Exception $e )

{

echo $e;

}

echo 'proc return message:'$Proc_Error.'

'; //输出来自存储过程中输出的变量

echo 'User id:'.$uId; //获取用户id

类型三:调用带返回结果集的方法

try {

$spname = 'P__Test_GetData';

$query = mysql_query ( "call $spname()", $conn ) or die ( "[$spname]Query failed:".mysql_error() );

while ( $row = mysql_fetch_array ( $query ) ) {

echo $row ['ProvinceID'].'::'.$row ['ProvinceName']; //输出数据集

}

} catch ( Exception $e ) {

echo $e;

}

类型四:调用带返回多个结果集的方法(目前只能通过mysqli来实现~~)

//PHP

$rows = array ();

$db = new mysqli($server,$user,$psd,$dbname);

if (mysqli_connect_errno()){

$this->message('Can not connect to MySQL server');

}

$db->query("SET NAMES UTF8");

$db->query("SET @Message");

if($db->real_query("call P__Test_GetData2(@Message)")){

do{

if($result = $db->store_result()){

while ($row = $result->fetch_assoc()){

array_push($rows, $row);

}

$result->close();

}

}while($db->next_result());

}

$db->close();

print_r($rows);

//Procedure

……

select * from T1 where ……

select * from T2 where ……

……

转载地址:http://rynzx.baihongyu.com/

你可能感兴趣的文章
面试中会遇到的正则题
查看>>
Spring之旅第八站:Spring MVC Spittr舞台的搭建、基本的控制器、请求的输入、表单验证、测试(重点)...
查看>>
数据结构与算法——常用排序算法及其Java实现
查看>>
你所不知的Webpack-多种配置方法
查看>>
React.js 集成 Kotlin Spring Boot 开发 Web 应用实例详解
查看>>
webpack+typescript+threejs+vscode开发
查看>>
python读excel写入mysql小工具
查看>>
如何学习区块链
查看>>
搜索问题的办法
查看>>
微信分销系统商城营销5大重点
查看>>
求职准备 - 收藏集 - 掘金
查看>>
htm5新特性(转)
查看>>
Linux-Centos启动流程
查看>>
php 设计模式
查看>>
后端技术精选 - 收藏集 - 掘金
查看>>
Laravel 服务容器
查看>>
mac安装kubernetes并运行echoserver
查看>>
多页架构的前后端分离方案(webpack+express)
查看>>
算法(第4版) Chapter 1
查看>>
前端技术选型的遗憾和经验教训
查看>>