存储过程的使用(三)使用DECLARE定义局部变量
程序员文章站
2022-07-07 20:12:04
使用DECLARE定义局部变量在流程语句的分析中,我们在存储过程中使用变量的声明与设置,由于这些变量也只能在存储过程中使用,因此也称为局部变量,变量的声明可以使用以下语法:DECLARE 变量名[,变量名2...] 数据类型(type) [DEFAULT value];DECLAREnumINTDEFAULT 10 ;-- 定义变量num,数据类型为INT型,默认值为10DECLARE mult_a,mult_b int;//定义多个变量其中......
使用DECLARE定义局部变量
在流程语句的分析中,我们在存储过程中使用变量的声明与设置,由于这些变量也只能在存储过程中使用,因此也称为局部变量,变量的声明可以使用以下语法:
DECLARE 变量名[,变量名2...] 数据类型(type) [DEFAULT value];
DECLARE num INT DEFAULT 10 ;
-- 定义变量num,数据类型为INT型,默认值为10
DECLARE mult_a,mult_b int; //定义多个变量
其中,DECLARE关键字是用来声明变量的;变量名即变量的名称,这里可以同时定义多个变量;type参数用来指定变量的类型;DEFAULT value子句将变量默认值设置为value,没有使用DEFAULT子句时,默认值为NULL。如图所示怎么会报错?因为声明变量只能存在于存储过程,与定义变量不同
声明后,我们就可以在存储过程使用该变量,设置变量值可以使用以下语法:
SET 变量名1 = expr [, 变量名2 = expr]
其中,SET关键字是用来为变量赋值的;expr参数是赋值表达式或某个值。一个SET语句可以同时为多个变量赋值,各个变量的赋值语句之间用逗号隔开。除了这种赋值方式,前面我们还提到过使用SELECT…INTO语句为变量赋值,那也是可行的
正确的例子:SET @a1 = 'zhangsan' ,@a2 =1029,@a3='2018-10-10'
如图所示为什么会报错?因为没有用声明的符号@
本文地址:https://blog.csdn.net/jikuicui7402/article/details/107170179
推荐阅读
-
使用七牛的镜像存储作为discuz的第三方服务器解决方案这样好嘛?
-
JSP教程(三)--JSP中”预定义变量”的使用
-
浅谈MySQL存储过程中declare和set定义变量的区别
-
SQL Server的通用分页存储过程 未使用游标,速度更快!
-
SQL 中sp_executesql存储过程的使用帮助
-
在SQL Server中使用SQL语句查询一个存储过程被其它所有的存储过程引用的存储过程名
-
浅谈MySQL存储过程中declare和set定义变量的区别
-
SQL 中sp_executesql存储过程的使用帮助
-
SQL Server的通用分页存储过程 未使用游标,速度更快!
-
分享:在存储过程中使用另一个存储过程返回的查询结果集的方法