十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
你创建一个存储过程C
成都创新互联公司是专业的宁津网站建设公司,宁津接单;提供成都网站设计、成都做网站,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行宁津网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
先执行存储过程A,并得到返回值
再判断返回值执行存储过程B
例如:
mysql
\d
//
mysql
create
procedure
test(v_name
char(20),out
v_id
int)
-
BEGIN
-
SELECT
id
into
v_id
from
t1
WHERE
name=v_name;
-
END;
-
//
mysql
create
procedure
test1(v_id
int,out
v_name
char(20))
-
BEGIN
-
SELECT
name
into
v_name
from
t2
where
id=v_id;
-
END;
-
//
mysql
create
procedure
test2(inout
v_name
char(20))
-
BEGIN
-
DECLARE
v_id
int;
-
CALL
test(v_name,v_id);
-
CALL
test1(v_id,v_name);
-
END;
-
//
mysql
set
@aa='xx‘//
Query
OK,
rows
affected
(0.00
sec)
mysql
call
test2(@aa)
//
Query
OK,
rows
affected
(0.01
sec)
mysql
select
@aa//
+------+
|
@aa
|
+------+
|
x2
|
+------+
1
row
in
set
(0.00
sec)
首先在运行输入 cmd
这样便打开了命令提示符,如下:
打开了之后在此输入 mysql -h你的IP或者花生壳的账户 -uroot -p该数据库的密码
例如:mysql -h30.158.59.78 -uroot -pabc123
mysql -htom.xicp.net -uroot -pabc123
php调用mysql存储过程和函数的方法
存储过程和函数是MySql5.0刚刚引入的。关于这方面的操作在PHP里面没有直接的支持。但是由于Mysql PHP API的设计,使得我们可以在以前的PHP版本中的mysql php api中支持存储过程和函数的调用。
在php中调用存储过程和函数。
1。调用存储过程的方法。
a。如果存储过程有 IN/INOUT参数,声明一个变量,输入参数给存储过程,该变量是一对,
一个php变量(也可以不必,只是没有php变量时,没有办法进行动态输入),一个Mysql
变量。
b。如果存储过程有OUT变量,声明一个Mysql变量。
mysql变量的声明比较特殊,必须让mysql服务器知道此变量的存在,其实也就是执行一条mysql语句。
入set @mysqlvar=$phpvar ;
c。使用mysql_query()/mysql_db_query()执行mysql 变量声明语句。
mysql_query("set @mysqlvar=$pbpvar");
这样,在mysql服务器里面就有一个变量,@mysqlar。如果是IN参数,那么其值可以由phpar传入。
d。 如果是存储过程。
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];
调用mysql存储或称 - mybatis调用mysql的存储过程(procedure),实现查询...
2021年1月19日step1:在mysqlcmd中新建存储过程: drop procedure ifexists queryCountByGrade ; delimiter//-- 定义存储过程结束符号为// create procedure qu..