mysql 触发器存储过程的区别_MySQL中的存储过程、函数与触发器

一.对待存储过程和函数的态度

优点:

1.存储过程只在创建时进行编译,sql语句则每次执行都需要编译。能提高数据库执行速度。

2.简单复杂操作结合事物一起封装。

3.复用性高。

4.安全性高,可指定存储过程的使用权。

在实际项目中应该尽量少用存储过程和函数,理由如下:

1.移植性差,在MySQL中的存储过程移植到sqlsever上就不一定可以用了。

2.调试麻烦,在db中报一个错误和在应用层报一个错误不是一个概念,那将是毁灭性打击,直接一个error:1045什么的更本毫无头绪。

3.扩展性不高。

所以在互联网时代大型项目应该尽量少使用(不使用)存储过程和函数。

二.创建存储过程

2.1什么是存储过程?

存储过程和存储函数都是一组sql语句的集合。这些语句集合被当做一个整体存入数据库中。

2.2创建存储过程的语法:

create procedure 存储过程名(参数列表)

sql语句

例子:

delimiter //

create procedure pro()

reads sql data

begin

select * from stu;

end

那么我们现在就有一个存储过程pro了,但是这个存储过程他是没有参数的,他只是执行一次查询操作。

我们现在来讲解一下这个存储过程的结构:

delimiter //  是将分号转化为//   因为在sql执行时当他遇到分号 ; 时他就讲停止所以我们必须将其转化为 //直到最后一行才会停止执行。

reads sql  data   解释characteristic的状态在这里是只读模式,其他的模式还有:no sql 没有sql语句 , ins  sql 不包含读和写的语句 , modifies sql data   包含写入数据的语句等等。

begin /***/  end   在存储过程中当有多条语句集合时我们必须使用begin和end

//   结束整个存储过程

2.3使用存储过程

在只是创建了一个存储过程,那么我们怎么来使用这个存储过程呢?

语法:call  存储过程名()

将上一个存储过程pro使用的例子:

call pro();

2.4创建一个带参数的存储过程

参数列表:存储过程的参数有三种类型:in,out,inout 分别表示传入参数和传出参数,和即传入也传出参数。

例子:首先我们来创建两张表:课程表是学生表的从表

create tablestu(

stu_idbigint primary keyauto_increment,#学号

stu_namevarchar(10) not null,#姓名

stu_majorint not null,#专业号

stu_sexchar,#性别

stu_in date,#入学日期

stu_birth date,#出生日期foreign key (stu_major) referencesmajor(ma_id)#专业外键设置

);create tablemajor(

ma_idint primary key,

ma_namevarchar(15),

ma_bossvarchar(10)

);insert into major values(1,"信管","张三");insert into major values(2,"电子商务","李四");insert into stu values(1,"小明",1,"男","2017-09-01","1998-12-23");insert into stu values(2,"小高",1,"男","2017-09-01","1998-05-01");insert into stu values(3,"小李",2,"男","2017-09-01","1999-04-01");

我们再来创建一个带有参数的存储过程找到学生的主修课的名字,代码如下:

delimiter //

create procedure pro1(in sname varchar(10),out ma varchar(10))

reads sql databegin

select ma_name into ma from major where ma_id = (select stu_major from stu where stu_name=sname);end

//

使用这个存储过程:代码如下:

set @ma="没查询之前";

call pro1("小李",@m

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
存储过程、存储函数触发器和视图在MySQL都有各自的用途。 存储过程是一组预编译的SQL语句,可以在数据库创建和存储,然后在需要的时候调用。它们的优点是可以实现模块化的设计,可以被多次调用,执行效率较高。存储过程通常用于执行复杂的数据库操作,例如数据的插入、更新、删除等。\[1\] 存储函数存储过程类似,也是一组预编译的SQL语句,但它们返回一个值。存储函数可以用于计算、转换数据等操作,并且可以在SQL语句直接调用。\[2\] 触发器是一种特殊的存储过程,它在数据库的表上定义,并在特定的事件发生时自动触发执行。触发器通常用于实现数据的约束、触发复杂的业务逻辑等。\[2\] 视图是一种虚拟的表,它是基于一个或多个表的查询结果构建的。视图可以简化复杂的查询操作,提供更方便的数据访问方式。视图通常用于隐藏敏感数据、简化数据查询、提供数据的不同展示方式等。\[2\] 综上所述,存储过程、存储函数触发器和视图在MySQL都有各自的用途,可以用于执行复杂的数据库操作、计算和转换数据、实现数据的约束和业务逻辑、以及提供方便的数据访问方式。 #### 引用[.reference_title] - *1* *2* [mysql的视图、触发器存储过程](https://blog.csdn.net/weixin_53002381/article/details/125796059)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [【MySQL基础】存储过程、存储函数触发器和视图](https://blog.csdn.net/qq_38149054/article/details/123298777)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值