存储过程参数、变量、条件判断解释及简单练习

本文详细介绍了MySQL存储过程的用途、参数类型(IN, OUT, INOUT)、变量赋值(SET, SELECT INTO, 用户变量, 局部变量)以及IF和CASE条件判断的语法和应用。通过实例解析如何创建存储过程并提供练习题以加深理解。" 135321615,7337247,反向传播过度拟合解决方案,"['人工智能', '深度学习', '机器学习', '优化算法', 'Python']
摘要由CSDN通过智能技术生成

什么是存储过程?为什么要用存储过程?

 

存储过程是具有名字的一段代码,完成一个特定的功能。存储过程保存在数据字典中

1.执行时简单(名字+参数)

2.存储过程中可以有一个、多个SQL语句

 

使用场景:(Mysql存储过程相对功能较弱)

1.将重复性很高的一些操作,封装到一个存储过程中,简化了对这些SQL的调用

2.批量处理 sql+循环

3.统一接口

 

语法:

delimiter $$-------定义结束标志,delimiter是分隔符的意思

CREATE

[DEFINER = { user | CURRENT_USER }]

PROCEDURE sp_name ([proc_parameter[,...]])

[characteristic ...] routine_body------------------------(过程体)



proc_parameter:

[ IN | OUT | INOUT ] param_name type

end $$

delimiter ;--------最后将结束标志改为分号





characteristic:

COMMENT 'string'

| LANGUAGE SQL

| [NOT] DETERMINISTIC

| { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }

| SQL SECURITY { DEFINER | INVOKER }

 

 

 

存储过程参数(in、out、inout)

 

1.需要输入------in参数

值 --100、赋值的变量 --set @xv=100; @xv

mysql> DELIMITER $$

mysql> CREATE PROCEDURE cou1(IN NAME VARCHAR(2))

-> BEGIN

-> SELECT dept_no FROM departments WHERE dept_name=NAME;

-> END $$

Query OK, 0 rows affected (0.00 sec)



mysql> DELIMITER ;
mysql> call cou1('b')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值