PHP中如何调用存储函数、存储过程及触发器?

2026-04-06 17:451阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1054个文字,预计阅读时间需要5分钟。

PHP中如何调用存储函数、存储过程及触发器?

我们学习了大量关于PHP的知识,但不确定你们如何调用存储函数,了解调用过程,以及其中的触发器是什么。是否已经完全掌握了呢?如果没有,那就随随便便地阅读相关章节,继续学习吧。

我们学习了解了这么多关于PHP的知识,不知道你们php中如何调用存储函数?调用存储过程?其中触发器是什么?是否已经完全掌握了呢,如果没有,那就跟随本篇文章一起继续学习吧

相关推荐:PHP中关于is,between,in等运算符的用法是什么?

在php中使用存储函数或存储过程的示意

//调用存储函数:

PHP中如何调用存储函数、存储过程及触发器?

$v1= $_POST["a];sv2 = $_POST["b]; $sq1 = "insert into tab1 (id, f2, f3)values ( null,nowO. fumnc1(Sv1 , $v2) )":$result= mysql_query($sql);

//调用存储过程:

$v1 = $_POST[ "usemame"];$v2=$_POST["pass"];sv3= $_POST["age"]; $sql ="callinsert_user(Sv1,$v2,$v3 ); ";llinsert_user)是一个存储过程,带3个参数,会将该3个参数数据写入<insert〉某个表中。 Sresult = mysql_queryO;

另一个使用存储过程返回结果集的例子

$sql m"call Get_User_iInfo( sid )“;//Get_User_info)是一个存储过程,其中会返回某个指定id 的用户信息$result = mysql_query(ssql);

这里得到的就是“结果集”了

触发器(trigger)

含义:

触发器,也是一段预先定义好的编程代码〈跟存储过程和存储函数一样〉,并有个名字。但:它不能调用,而是,在某个表发生某个事件(增,删,改〉的时候,会自动“触发”而调用起来。

定义形式:

create trigger触发器名︰触发时机触发事件on表名foreach rowasbegin //这里,才是编程的位置,也就是触发器的内部语句end3

说明:

1,触发时机,只有2个: before《在....之前), after《在....之后〉﹔2,触发事件,只有3个: insert, update , delete

2,触发事件,只有3个: insert,update , delete

3,即触发器的含义是:在某个表上进行insert(或 update,或 delete)之前〈或之后〉,会去执行其中写好的代码(语句);即每个表只有6个情形会可能调用该触发器,

4,通常,触发器用于在对某个表进行增删改的操作的时候,需要同时去做另外一件事情的时候;5,在触发器的内部,有2个关键字代表某种特定的含义,可以用了获取数据∶

new:

它代表当前正要执行的 insert update 的时候的“新行”数据﹔通过它,可以获取这一新行数据的任意一个字段的值,形式为:

set@v1 = new.id;

//获得该新插入或update行的id字段的值(前提是有该id)

set@v2 = new.age;//同上,

old:

它代表当前正要执行的delete的时候的“旧行”数据,通过它,可以获取这一旧行数据的任意一个字段的值,形式为:

set @v1 = old.id:I

获得该新插入或update行的id字段的值(前提是有该id)

set @v2 = old.age;//同上;

#先删除tab_int_max中的所有数据:

delete from tab_int_max1;

#取得tab_int中的f1字段的最大值,并存入变量@maxfselect max(f1) into @maxf1 from tab_int;

#然后,根据该得到的f1字段的最大值,作为条件,取出3个字段的值:

select f2 into @v2 from tab_int where f1 = @maxf1; select f3 into @v3 from tab_int _ where f1 = @maxf1;#然后,将@maxf1,@v2,@v3插入到表tab_int_max1 insert into tab_int_max1 (f1,f2,f3)values( @maxf1,@v2,@v3);end; #再建一个触发器,在表tab_int进行insert之前,将该行数据#也同时插入到一个跟其类似结果的表(tab_int_some)中 :CREATE TABLE tab_int_some ( id int(11) DEFAULT NULL,age tinyint(4) DEFAULT NULL); create trigger copy_data before insert on tab_int for each rowbegin set @v1 = new.f1; #获得新行的字段f1的值; set @v2 = new.f2;#获得新行的字段f2的值; insert into tab_int_some(id,age)values(@v1,@v2);end;

推荐学习:php视频教程

以上就是php中如何调用存储函数?调用存储过程?其中触发器是什么?的详细内容,更多请关注自由互联其它相关文章!

本文共计1054个文字,预计阅读时间需要5分钟。

PHP中如何调用存储函数、存储过程及触发器?

我们学习了大量关于PHP的知识,但不确定你们如何调用存储函数,了解调用过程,以及其中的触发器是什么。是否已经完全掌握了呢?如果没有,那就随随便便地阅读相关章节,继续学习吧。

我们学习了解了这么多关于PHP的知识,不知道你们php中如何调用存储函数?调用存储过程?其中触发器是什么?是否已经完全掌握了呢,如果没有,那就跟随本篇文章一起继续学习吧

相关推荐:PHP中关于is,between,in等运算符的用法是什么?

在php中使用存储函数或存储过程的示意

//调用存储函数:

PHP中如何调用存储函数、存储过程及触发器?

$v1= $_POST["a];sv2 = $_POST["b]; $sq1 = "insert into tab1 (id, f2, f3)values ( null,nowO. fumnc1(Sv1 , $v2) )":$result= mysql_query($sql);

//调用存储过程:

$v1 = $_POST[ "usemame"];$v2=$_POST["pass"];sv3= $_POST["age"]; $sql ="callinsert_user(Sv1,$v2,$v3 ); ";llinsert_user)是一个存储过程,带3个参数,会将该3个参数数据写入<insert〉某个表中。 Sresult = mysql_queryO;

另一个使用存储过程返回结果集的例子

$sql m"call Get_User_iInfo( sid )“;//Get_User_info)是一个存储过程,其中会返回某个指定id 的用户信息$result = mysql_query(ssql);

这里得到的就是“结果集”了

触发器(trigger)

含义:

触发器,也是一段预先定义好的编程代码〈跟存储过程和存储函数一样〉,并有个名字。但:它不能调用,而是,在某个表发生某个事件(增,删,改〉的时候,会自动“触发”而调用起来。

定义形式:

create trigger触发器名︰触发时机触发事件on表名foreach rowasbegin //这里,才是编程的位置,也就是触发器的内部语句end3

说明:

1,触发时机,只有2个: before《在....之前), after《在....之后〉﹔2,触发事件,只有3个: insert, update , delete

2,触发事件,只有3个: insert,update , delete

3,即触发器的含义是:在某个表上进行insert(或 update,或 delete)之前〈或之后〉,会去执行其中写好的代码(语句);即每个表只有6个情形会可能调用该触发器,

4,通常,触发器用于在对某个表进行增删改的操作的时候,需要同时去做另外一件事情的时候;5,在触发器的内部,有2个关键字代表某种特定的含义,可以用了获取数据∶

new:

它代表当前正要执行的 insert update 的时候的“新行”数据﹔通过它,可以获取这一新行数据的任意一个字段的值,形式为:

set@v1 = new.id;

//获得该新插入或update行的id字段的值(前提是有该id)

set@v2 = new.age;//同上,

old:

它代表当前正要执行的delete的时候的“旧行”数据,通过它,可以获取这一旧行数据的任意一个字段的值,形式为:

set @v1 = old.id:I

获得该新插入或update行的id字段的值(前提是有该id)

set @v2 = old.age;//同上;

#先删除tab_int_max中的所有数据:

delete from tab_int_max1;

#取得tab_int中的f1字段的最大值,并存入变量@maxfselect max(f1) into @maxf1 from tab_int;

#然后,根据该得到的f1字段的最大值,作为条件,取出3个字段的值:

select f2 into @v2 from tab_int where f1 = @maxf1; select f3 into @v3 from tab_int _ where f1 = @maxf1;#然后,将@maxf1,@v2,@v3插入到表tab_int_max1 insert into tab_int_max1 (f1,f2,f3)values( @maxf1,@v2,@v3);end; #再建一个触发器,在表tab_int进行insert之前,将该行数据#也同时插入到一个跟其类似结果的表(tab_int_some)中 :CREATE TABLE tab_int_some ( id int(11) DEFAULT NULL,age tinyint(4) DEFAULT NULL); create trigger copy_data before insert on tab_int for each rowbegin set @v1 = new.f1; #获得新行的字段f1的值; set @v2 = new.f2;#获得新行的字段f2的值; insert into tab_int_some(id,age)values(@v1,@v2);end;

推荐学习:php视频教程

以上就是php中如何调用存储函数?调用存储过程?其中触发器是什么?的详细内容,更多请关注自由互联其它相关文章!