本文主要是介绍mysql编程--从入门到入土,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
- 创建存储过程
- 调用存储过程
- 删除存储过程
- 可能出现的问题
- MySQL变量
- 系统变量
- 定义变量
- 查询变量
- 变量的简单使用
- 局部变量
- if语句
- 参数
创建存储过程
create procedure p()
begin
select * from emp;
end;
调用存储过程
call p;
删除存储过程
drop procedure if exists p;
可能出现的问题
在dos命令窗口时,遇到分号则会执行语句。解决办法:运行下方语句,服务器不再会遇到分号结尾了,而是两个斜杠
delimiter// – 告诉服务器,遇到两个斜杠再执行sql语句
MySQL变量
系统变量
系统变量由系统提供,不是用户定义的,属于服务器层面
查看系统变量
show global variables; -- 全局的
show session variables;-- 当前会话的(当前连接)
设置系统变量
set [global I session] 系统变量名 = 值;
注意:当MySQL服务重启后,之前的配置会失效
定义变量
set @name = '张三';
定义一个变量name,值为张三
查询变量
select @name;
-- 查询多个变量
select @name,@age,@sex,@information;
注:如果没有声明变量直接查询的话结果为null
变量的简单使用
-- 我们也可以在查询中调用变量
select * from student where ename=@name;
-- 同时也可以将查询结果赋值给变量
select age into @age from student where ename='张三';
局部变量
在存储过程中可以使用变量,使用declare声明,只在begin和end之间有效
CREATE DEFINER=`root`@`localhost` PROCEDURE `pee`()
BEGIN
-- 声明两个变量declare age int default 0;
-- 为变量赋值set age =18;
END
if语句
语法格式:
if 条件 then...
else if 条件 then...
else if 条件 then...
else...
end if
实战练习:
通过工资来判断收入群体,sal超过10000的为高收入群体,5000以上为中等收入群体,5000一下 为低收入群体
CREATE PROCEDURE p()
begin declare sal int default 0;declare result varchar(20);set sal := 5001;if sal>10000 thenset result = '高收入';elseif sal>5000 thenset result = '中等收入';elseset result = '低收入';end if;select result;
end
参数
in:入参(未指定时,默认入参)写入数据但并不导出
out:出参 不写入数据,输出参数
inout:既入参又出参
CREATE PROCEDURE sal(in sal int,out result varchar(20))
# 此处我们定义了一个sal(工资),result输出结果,这两个变量均欸局部变量,在存储过程外只能访问到用户变量,但result作为一个输出结果,在存储过程外我们是能查到的
begin
# 我们在创建存储过程时已经定义了sal,此时我们无需再定义值if sal>10000 thenset result = '高收入';elseif sal>5000 thenset result = '中等收入';elseset result = '低收入';end if;select result;
end# 调用存储过程call sal(7000,@result); -- 在sal数据处写入值,运行存储过程,因为我们没有输出语句此时没有任何内容被输出#查询我们曾赋值的result,输出结果select @result
create procedure p1(inout sal int) #此时定义inout即是入参又是出参
beginset sal=sal*1.1;
end;set @sal=10000; #定义sal,此时的sal与上方的sal无关,只是一个赋值的变量,所以变量名随意,下方同理,但要与这行定义的函数相匹配
call p1(@sal); #给存储过程赋值,输出结果会直接赋值到sal变量上
select @sal; #查询变量
这篇关于mysql编程--从入门到入土的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!