weixin_51660174 2021-06-30 15:33 采纳率: 37.5%
浏览 30
已采纳

这个怎么搞,加急,加急

编写存储过程,要求当“大数据技术与应用”专业的学生来就餐时,调用该存储过程,输入学号,能自动识别出该生的专业,并为“大数据技术与应用”专业的学生就餐费用打九折。

  • 写回答

3条回答 默认 最新

  • Lymj丶 2021-06-30 15:59
    关注
    CREATE TABLE `student` (
      `stu_no` int(11) NOT NULL,
      `subject` varchar(32) DEFAULT NULL,
      PRIMARY KEY (`stu_no`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
    
    INSERT INTO `data_liri`.`student`(`stu_no`, `subject`) VALUES (1, '大数据技术与应用');
    INSERT INTO `data_liri`.`student`(`stu_no`, `subject`) VALUES (2, '大数据技术与应');
    INSERT INTO `data_liri`.`student`(`stu_no`, `subject`) VALUES (3, '大数据技术与应用4');
    
    DROP PROCEDURE IF EXISTS PROC_DINNER;
    CREATE PROCEDURE PROC_DINNER(no int, cost float)
    BEGIN
        declare c float;
        set @s := '';
        set @s := (select subject from student where stu_no = no);
        if @s = '大数据技术与应用'
        then
            set c = cost * 0.9;
        else
            set c = cost;
        end if;
        select c;
    end;
    
    测试用例:call proc_dinner(1,200);
    返回结果:180
    

    不知道满不满足你描述的需求,这个逻辑要求学生表以学号为主键。

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

报告相同问题?

悬赏问题

  • ¥15 DIFY API Endpoint 问题。
  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突