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; 	 #查询变量
相关推荐
洛豳枭薰1 小时前
Innodb一次更新动作
mysql
Σίσυφος19001 小时前
PCL法向量估计 之 方向约束法向量(Orientation Guided Normal)
数据库
老毛肚1 小时前
手写mybatis
java·数据库·mybatis
海山数据库1 小时前
移动云大云海山数据库(He3DB)postgresql_anonymizer插件原理介绍与安装
数据库·he3db·大云海山数据库·移动云数据库
云飞云共享云桌面1 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
2501_927993531 小时前
SQL Server 2022安装详细教程(图文详解,非常详细)
数据库·sqlserver
星火s漫天1 小时前
第一篇: 使用Docker部署flask项目(Flask + DB 容器化)
数据库·docker·flask
xcLeigh1 小时前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
威迪斯特1 小时前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构
xu_yule1 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式