本文目錄一覽:
php調用mysql存儲過程,如何實現。 我的代碼如下:
mysql存儲過程返回2個資源,第一個是執行信息,第二個是存儲過程返回結果。
mysql_*系列函數無法獲取超過1個資源,需使用mysqli或PDO代替。
PDO:
$stmt = $db-prepare(“CALL pro_rb_save(?,?,@return_msg);”);
$stmt-bindParam(1, $a);
$stmt-bindParam(2, $b);
$stmt-execute ();
$outputArray = $db-query(“select @return_msg”)-fetch(PDO::FETCH_ASSOC);
var_export($return_msg);
php 怎麼調用,mysql 存儲過程 exec,煩死了
1。執行 call procedure()語句。
也就是mysql_query(“call proceduer([var1]…)”);
2. 如果有返回值,執行select @ar,返回執行結果。
mysql_query(“select @var)”
接下來的操作就和php執行一般的mysql語句一樣了。可以通過mydql_fetch_row()等函數獲得結果。
如果時函數。 直接執行 select function() 就可以了。
$host=”localhost”;
$user=”root”;
$password=”11212″;
$db=”samp_db”;
$dblink=mysql_connect($host,$user,$password)
or die(“can’t connect to mysql”);
mysql_select_db($db,$dblink)
or die(“can’t select samp_db”);
$res=mysql_query(“set @a=$password”,$dblink);
$res=mysql_query(“call aa(@a)”,$dblink);
$res=mysql_query(“select @a”,$dblink);
$row=mysql_fetch_row($res);
echo $row[0];
PHP下如何創建MYSQL存儲過程
直接上代碼:
mysql_connect(“localhost”,”user”,”pwd”);
mysql_select_db(‘testdata’) or die (mysql_error());
$sql = “create procedure tb_neaten (in rec int,in pa varchar(15),in qy decimal(10,2),in ar varchar(6))
begin
update test1 set qty=qty-qy where recordnum=rec;
insert into test2 set bname=pa,area=ar,qty=qy,date=date_format(now(),’%Y%m%d’),time=date_format(now(),’%Y%m%d’);
end;”;
mysql_query($sql) or die (mysql_error());
若是存儲過程里含有捕獲select結果的語句時,需在mysql_connect時調整參數
mysql_connect(“localhost”,”user”,”password”,1,131072)
執行時,直接運行
mysql_query(tb_neaten(va1,va2,va3,va4));
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/253906.html