存储过程定义时间变量_No.3 MySQL 存储过程之“退休时间计算器”

本期,我们来用MySQL数据库中的存储过程,即create procedure,制作一个简易版的”退休时间计算器”。主要涉及到的几个知识点:

1、创建存储过程

delimiter // 

create procedure p_name( )

begin

......

end

//

2、流程控制语句if

if....then

elseif....then

elseif....then

else

end if;

3、其他语

模糊查询:like,not like,‘’%”代表任意个字符,“_”代表一个字符

时间函数:date_add()函数

输入参数:in

输出参数:out

二、用Navicat Premium 软件制作的“退休时间计算器”,具体码如下:

CREATE DEFINER =`root`@`localhost` PROCEDURE `退休时间计算器` (in sex char ( 1 ), in birth_date date ,in gangwei varchar (6), in zhicheng varchar (15), out tx_age varchar (15), ou t tx_date varchar ( 3 0 )) BEGIN if sex = ' 男 ' then set tx_age = ' 60岁 '; set tx_date = date_add (birth_date, interval  60 year); elseif sex = ' 女 ' and zhicheng like '%高级%' then set tx_age = ' 55岁 或 60岁 '; set tx_date = concat(date_add (birth_date ,interval 55 year),' 或 ', date_ad d(birth_date, interval  60 year)); elseif sex = '女' and gangwei like '%工勤%' then set tx_age = ' 50岁 '; set tx_date = date_add (birth_date ,interval 50 year); else set tx_age = ' 55岁 '; set tx_date = date_add (birth_date ,interval 55 year); end if; END 截图如下:

5226dbcef941629d13e147ca68badc88.png

保存并运行后出现输入界面:

69065509d478157c67d37d131a5e8d21.png

点击确定按钮后,显示运行结果:

8abf0c12b44e388c3ee5f370de39ceaf.png

若希望参数以中文形式显示,我们可以替换一下字段名,具体如下:

fd97a3a9d5e966fe4a43641c86ebe3d2.png

具体代码: CREATE DEFINER=`root`@`localhost` PROCEDURE `退休时间计算器1`(in 性别 char(1),in 出生日期 date,in 岗位 varchar(6),in zhicheng varchar(15),out 拟退休年龄 varchar(15),out 拟退休时间 varchar(30)) BEGIN if 性别 = '男' then set 拟退休年龄 = '60岁'; set 拟退休时间 = date_add(出生日期,interval 60 year); elseif 性别 = '女' and zhicheng like '%高级%' then set 拟退休年龄 = '55岁 或 60岁'; set 拟退休时间 = concat(date_add(出生日期,interval 55 year),'或',date_add(出生日期,interval 60 year)); elseif 性别 = '女' and 岗位 like '%工勤%' then set 拟退休年龄 = '50岁'; set 拟退休时间 = date_add(出生日期,interval 50 year); else set 拟退休年龄 = '55岁'; set 拟退休时间 = date_add(出生日期,interval 55 year); end if; END 输入界面与结果:

6c06fc5d76adcfbbdfc9b8834048f3de.png

运行结果:

927b7a1121cd8e76271730a5718754d6.png


--The End--
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值