MySQL 创建存储过程和视图

本文介绍了一个简单的MySQL存储过程“pr_add”,该过程接受两个整数参数并返回它们的和。此外,还展示了如何创建一个存储过程来计算user表中的记录数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

“pr_add” 是个简单的 MySQL 存储过程,这个MySQL 存储过程有两个 int 类型的输入参数 “a”、“b”,返回这两个参数的和。
1. drop procedure if exists pr_add;
2. 计算两个数之和

create procedure pr_add   
(   
a int,   
b int   
)   
begin   
declare c int;   
if a is null then   
set a = 0;   
end if;   
if b is null then   
set b = 0;   
end if;   
set c = a + b;   
select c as sum;   
/*   
return c;  
不能在 MySQL 存储过程中使用。return 只能出现在函数中。
*/   
end;  
mysql> DELIMITER //  
mysql> CREATE PROCEDURE proc1(OUT s int)  
    -> BEGIN 
    -> SELECT COUNT(*) INTO s FROM user;  
    -> END 
    -> //  
mysql> DELIMITER ; 

链接 http://database.51cto.com/art/201006/203159.htm##1

create view stu_class(id,name,glass) as select student.s_id,student.name,stu_idfo.class from student,stu_infowhere student.s_id=stu_info.s_id;

https://blog.youkuaiyun.com/wangxingfan316/article/details/78953649

### MySQL 存储过程视图的区别 #### 定义差异 存储过程是一组为了完成特定功能的 SQL 语句集,经过编译后保存在数据库中。用户可以通过指定存储过程的名字及其参数值来调用并执行它[^4]。而视图则是一个虚拟表,其内容由查询定义,通常用于提供一种简化复杂查询的方式或是控制访问权限的一种手段[^5]。 #### 创建方式的不同 对于存储过程而言,在创建时会涉及到编写一组或多条SQL命令,并将其作为一个整体进行打包处理。这其中包括但不限于数据操作语言(DML),事务管理以及流程控制结构等高级特性。相反,视图主要基于单一的选择查询(SELECT statement)构建而成,该查询可能涉及单个或多个基础物理表格中的字段组合[^1]。 #### 执行机制上的差别 当调用一个已存在的存储过程时,实际上是启动了一次预先设定好的程序运行实例,期间可能会传递输入/输出参数给这个过程体内部使用。相比之下,每次查询视图实际上都是重新执行一次其所代表的基础SELECT语句,这意味着视图并不实际占用额外的空间去储存结果集副本。 #### 参数支持情况 值得注意的是,存储过程能够接受来自外部环境传入的各种形式的参数(如IN, OUT 或者 INOUT),从而实现更加灵活的功能定制化需求。然而,视图本身不具备接收任何外界变量的能力,也就是说它们总是返回固定模式的结果集合。 ```sql -- 创建存储过程示例 DELIMITER $$ CREATE PROCEDURE GetDailyUserGrowth(IN start_date DATE, OUT total_users INT) BEGIN SELECT COUNT(*), date_joined INTO total_users FROM auth_user WHERE date(date_joined) >= start_date; END$$ DELIMITER ; -- 使用视图获取每日新增用户的数量 CREATE VIEW daily_user_growth AS SELECT DATE_FORMAT(auth_user.date_joined,'%Y-%m-%d') as date_time ,COUNT(*) as visit_count FROM auth_user GROUP BY date_time ORDER BY date_time DESC ; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值