文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

php中怎么调用存储函数和存储过程,它的触发器是什么

2023-06-20 12:24

关注

本篇内容介绍了“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_max1insert 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 rowbeginset @v1 = new.f1;#获得新行的字段f1的值;set @v2 = new.f2;#获得新行的字段f2的值;insert into tab_int_some(id,age)values(@v1,@v2);end;

“php中怎么调用存储函数和存储过程,它的触发器是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯