mysql编程--从入门到入土

创建存储过程

create procedure p()

begin

select * from emp;

end;

调用存储过程

call p;

删除存储过程

drop procedure if exists p;

可能出现的问题

在dos命令窗口时,遇到分号则会执行语句。解决办法:运行下方语句,服务器不再会遇到分号结尾了,而是两个斜杠

delimiter// -- 告诉服务器,遇到两个斜杠再执行sql语句

MySQL变量

系统变量

复制代码
系统变量由系统提供,不是用户定义的,属于服务器层面

查看系统变量

sql 复制代码
show global variables; -- 全局的
show session variables;-- 当前会话的(当前连接)

设置系统变量

sql 复制代码
set [global I session] 系统变量名 = 值;

注意:当MySQL服务重启后,之前的配置会失效

定义变量

sql 复制代码
set @name = '张三';
定义一个变量name,值为张三

查询变量

sql 复制代码
select @name;
-- 查询多个变量
select @name,@age,@sex,@information;
复制代码
注:如果没有声明变量直接查询的话结果为null

变量的简单使用

sql 复制代码
-- 我们也可以在查询中调用变量
select * from student where ename=@name;
-- 同时也可以将查询结果赋值给变量
select age into @age from student where ename='张三';

局部变量

复制代码
在存储过程中可以使用变量,使用declare声明,只在begin和end之间有效
sql 复制代码
CREATE DEFINER=`root`@`localhost` PROCEDURE `pee`()
BEGIN
-- 声明两个变量
	declare age int default 0;
-- 为变量赋值
	set age =18;
END

if语句

语法格式:

bash 复制代码
if 条件 then
	...
else if 条件 then
	...
else if 条件 then
	...
else
	...
end if

实战练习:

通过工资来判断收入群体,sal超过10000的为高收入群体,5000以上为中等收入群体,5000一下 为低收入群体

sql 复制代码
CREATE PROCEDURE p()
begin 
  declare sal int default 0;
	declare result varchar(20);
	set sal := 5001;
	if sal>10000 then
		set result = '高收入';
	elseif sal>5000 then
		set result = '中等收入';
	else
		set result = '低收入';
	end if;
	select result;
end

参数

in:入参(未指定时,默认入参)写入数据但并不导出

out:出参 不写入数据,输出参数

inout:既入参又出参

sql 复制代码
CREATE PROCEDURE sal(in sal int,out result varchar(20))
# 此处我们定义了一个sal(工资),result输出结果,这两个变量均欸局部变量,在存储过程外只能访问到用户变量,但result作为一个输出结果,在存储过程外我们是能查到的
begin 
# 我们在创建存储过程时已经定义了sal,此时我们无需再定义值
	if sal>10000 then
		set result = '高收入';
	elseif sal>5000 then
		set result = '中等收入';
	else
		set result = '低收入';
	end if;
	select result;
end
 # 调用存储过程
 call sal(7000,@result); -- 在sal数据处写入值,运行存储过程,因为我们没有输出语句此时没有任何内容被输出
 #查询我们曾赋值的result,输出结果
 select @result
sql 复制代码
create procedure p1(inout sal int) #此时定义inout即是入参又是出参
begin
	set sal=sal*1.1;
end;

set @sal=10000;  #定义sal,此时的sal与上方的sal无关,只是一个赋值的变量,所以变量名随意,下方同理,但要与这行定义的函数相匹配
call p1(@sal);   #给存储过程赋值,输出结果会直接赋值到sal变量上
select @sal; 	 #查询变量
相关推荐
NCIN EXPE3 小时前
redis 使用
数据库·redis·缓存
MongoDB 数据平台3 小时前
为编码代理引入 MongoDB 代理技能和插件
数据库·mongodb
极客on之路3 小时前
mysql explain type 各个字段解释
数据库·mysql
代码雕刻家3 小时前
MySQL与SQL Server的基本指令
数据库·mysql·sqlserver
lThE ANDE3 小时前
开启mysql的binlog日志
数据库·mysql
yejqvow123 小时前
CSS如何控制placeholder文字的颜色_使用--placeholder伪元素
jvm·数据库·python
oLLI PILO3 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
m0_743623923 小时前
HTML怎么创建多语言切换器_HTML语言选择下拉结构【指南】
jvm·数据库·python
pele4 小时前
Angular 表单中基于下拉选择动态启用字段必填校验的完整实现
jvm·数据库·python