Powder_Snow_ 2022-12-16 01:33 采纳率: 78.9%
浏览 136
已结题

MySQL自定义函数

img


数据库链接:https://pan.baidu.com/s/1xgLgKKOrhUR6UmO3yIZTGw
提取码:gt5m

  • 写回答

6条回答 默认 最新

  • AllenGd 大数据领域优质创作者 2022-12-16 09:40
    关注

    第一题:定义函数fun_sum()计算n!

    img

    create function fun_sum(n int)
    returns int #返回值类型
    begin
        declare i int default 1; #变量声明及初始化
        declare ans int default 1;
        while i<=n do
            set ans=ans*i;
            set i=i+1;
        end while;   /*注意:end while后面要加分号*/
        return ans;  -- 返回结果
    end
    
    select fun_sum(4)
    

    img


    第二题:

    img

    delimiter $$
    CREATE FUNCTION fun_class ( s_no VARCHAR ( 20 ) ) 
    RETURNS VARCHAR ( 20 ) 
    READS SQL DATA 
    BEGIN
        DECLARE    classname VARCHAR ( 20 );
        SELECT
            clname INTO classname 
        FROM
            student s
            LEFT JOIN class c ON s.classno = c.classno 
        WHERE
            sno = s_no;
        RETURN classname;
    END;
    $$
    
    select fun_class('2018010101');
    

    img


    第三题:

    img

    delimiter $$
    CREATE FUNCTION fun_compare (peacetime decimal(5,1),practice decimal(5,1)) 
    RETURNS VARCHAR (20) 
    READS SQL DATA 
    BEGIN
        DECLARE    compareresult VARCHAR ( 20 );
      case when peacetime = practice then set compareresult = '比较均衡';
               when peacetime > practice then set compareresult = '加强实践';
                 when peacetime < practice then set compareresult = '注重平时' ;
                end case ;
        RETURN compareresult;
    END;
    $$
    
    select sno,peacetime,practice,fun_compare(peacetime,practice) from score
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 12月26日
  • 已采纳回答 12月18日
  • 创建了问题 12月16日

悬赏问题

  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败
  • ¥15 树莓派5怎么用camera module 3啊
  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗