编写存储过程,要求当“大数据技术与应用”专业的学生来就餐时,调用该存储过程,输入学号,能自动识别出该生的专业,并为“大数据技术与应用”专业的学生就餐费用打九折。
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
不知道满不满足你描述的需求,这个逻辑要求学生表以学号为主键。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 西门子S7-Graph,S7-300,梯形图
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!
- ¥15 永磁直线电机的电流环pi调不出来
- ¥15 用stata实现聚类的代码
- ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效
- ¥15 悬赏!微信开发者工具报错,求帮改