SQL笔记四变量和存储过程

变量

系统变量

系统提供,是服务器提供的

#使用语法
#查看系统所有变量
show global/*全局*/|session/*会话,不写也可以当作查看会话变量*/ variables
#查看满足条件的部分系统变量
show global|session variables like '%char%'
#查看指定的某个系统变量的值
select @@系统变量名
select @@global|session.系统变量名#加修饰
#为某个系统变量名赋值 
set global|session 系统变量名 =set @@global|session.系统变量名 =
全局变量

作用域:服务器每次启动服务器为所有全局变量,针对所有会话连接有效,但是不能跨重启

会话变量

作用域:只针对于当前会话

自定义变量

不是由系统提供

使用步骤:声明 赋值 使用(查看 比较 运算等)

用户变量

作用域:针对于当前会话

应用于任何地方

#声明并初始化
set @用户变量名=set @用户变量名:=select @用户变量名:=#赋值
#方法一和声明一样
set @用户变量名=set @用户变量名:=select @用户变量名:=#方法二
select 字段 into 变量名
from#案例
SELECT COUNT(*) INTO @count
FROM employees;
#使用
#查看
select @用户变量名
局部变量

作用域:只能局部有效,在begin end中,并且只能在第一句

#声明
declare 变量名 类型
declare 变量名 类型 default#赋值
#方法一
set 变量名=set 变量名:=select @变量名:=#方法二
select 字段 into 变量名
from#使用
#查看
select 变量名

存储过程和函数

存储过程

一组预先编译好的sql语句的集合,理解成批处理语句

优点:1.提高代码的重用性

2.简化操作

3.减少了编译次数并且减少了和数据库服务器的连接次数,提高效率

#创建语法
create procedure 存储过程名(参数列表)
begin
	存储过程体
end
/*
参数列表包含三部分
参数模式 参数名 参数类型
举例:
IN stuname  VARCHAR(20)
*/
#参数模式
INT#参数可以作为输入,需要传入值
OUT#作为输出,可以作为返回值
INOUT#输入和输出,可以传入,可以返回
#如果存储过程只有一句话可以省略begin end
#存储过程中的每条SQL语句的结尾要求必须加分号;
#存储过程结尾可以使用DELIMITER重新设置
#语法案例:
delimiter 结束标识
#调用语法
call 存储过程名(实数列表);
#案例 空参数
DELIMITER $
CREATE PROCEDURE myp1()
BEGIN
	INSERT INTO admin(username,`password`)
	VALUES('john1','0000'),('liu','0000');
END $

CALL myp1()$
#案例 输入参数
CREATE PROCEDURE myp2(IN beautyName VARCHAR(20))
BEGIN
	SELECT bo.*
	FROM boys bo
	RIGHT JOIN beauty b ON bo.id = b.boyfriend_id
	WHERE b.name=beautyName;
END $

CALL myp2('柳岩')$;
#案例
CREATE PROCEDURE myp4(IN username VARCHAR(20),IN PASSWORD VARCHAR(20))
BEGIN
	DECLARE result INT DEFAULT 0;#变量
	SELECT COUNT(*) INTO result
	FROM admin a
	WHERE username=a.username
	AND a.password = PASSWORD;
	
	SELECT IF(result>0,'y','n');
END $

CALL myp4('john','8888')$;
#案例 输出
DELIMITER $
CREATE PROCEDURE myp6(IN beautyName VARCHAR(20),
			OUT boyName VARCHAR(20),
			OUT usercp INT)
BEGIN
	SELECT bo.boyname,bo.userCP INTO boyName,usercp
	FROM boys bo
	INNER JOIN beauty b ON bo.id=b.boyfriend_id
	WHERE b.name=beautyName;
END $
CALL myp6('王语嫣',@bName,@userCp)$;

SELECT @bName,@userCp;
#案例 inout
CREATE PROCEDURE myq8(INOUT a INT,INOUT b INT)
BEGIN
	SET a=a*2;
	SET b=b*2;
END $
#删除存储过程
drop procedure 存储过程名
#查看存储过程的信息
show create procedure 存储过程名
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值