mysql高级【2】:mysql游标、异常错误处理、存储函数

本文介绍了如何在MySQL中使用存储函数处理用户表数据,包括利用存储函数ageDegree判断年龄阶段,创建存储过程解决用户id重复问题,并进行异常错误处理。通过示例展示了调用测试过程及注意事项,强调了错误代码映射、存储函数的使用限制和处理程序声明的位置等关键点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

由于都是简单的使用,所以我直接把三个知识点都写入了一个例子里了,使用的数据库是上一次博客新建的数据库

https://blog.youkuaiyun.com/qq_26584263/article/details/82116667

1、问题:

有个用户表,新增的时候如果存在id已经存在了那么就返回 “用户id已存在!”,查询全部数据的名字和年龄段字符串,年龄段为

童年: 0岁—6岁

少年: 7岁—17岁

成年:大于等于18岁

假如有数据:

张三丰 12岁

李思 22岁

返回的数据就应该是

张三丰在少年阶段;李思在成年阶段

2、解决问题:

(1)、首先新建一个存储函数,判断不同年龄的阶段的值  ageDegree函数,函数和java中的函数差不多,判断完后返回结果,存储函数里面是可以使用sql语句的。

CREATE  FUNCTION `ageDegree`(age int) RETURNS varchar(50)
    DETERMINISTIC
begin
      declare str varchar(50);
      if age < 7 then
      set str = "童年";
      elseif age < 18 then
      set str = "少年";
      else
      set str = "成年";
      end if;
      return (str);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值