CREATE PROCEDURE proStudentByNo21(@sNo char(7), @sName
varchar(20) OUTPUT, @avg numeric(5, 1) OUTPUT )
AS
BEGIN
SELECT @sName=studentName
FROM Student WHERE studentNo=@sNo
SELECT @avg=avg(score)
FROM Score WHERE studentNo=@sNo
GROUP BY studentNo
END
执行存储过程proStudentByNo2 1
DECLARE @sNamevarchar(20), @avg numeric(5, 1)
EXECUTE proStudentByNo21 '0800001', @sName OUTPUT, @avg OUTPUT
SELECT @sName, @avg
把以上SQLServer版本的存储过程改为MYSQL版本并运行
(萌新,求教,求救大佬)
如何把以下SQLServer版本的存储过程改为MYSQL版本?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- lshen01 2023-03-15 18:26关注
参考GPT和自己的思路:
可以把SQL Server版本的存储过程改为MYSQL版本的,需要进行以下步骤:
修改存储过程的名称,以符合MYSQL的要求。
修改存储过程的参数类型和声明方式。MYSQL使用不同的数据类型和参数声明方式,需要进行相应修改。
修改存储过程的SQL语句,以符合MYSQL的要求。MYSQL对SQL语句语法和关键字的要求与SQL Server有所不同,需要进行适当的调整。
在MYSQL中创建相应的数据库和表,以便存储过程可以正确地执行。
针对上述SQL Server版本的存储过程,可以按照以下方式改为MYSQL版本:
DELIMITER $$
CREATE PROCEDURE proStudentByNo21(IN sNo CHAR(7), OUT sName VARCHAR(20), OUT avg DOUBLE)
BEGINSELECT studentName INTO sName FROM Student WHERE studentNo = sNo;
SELECT AVG(score) INTO avg FROM Score WHERE studentNo = sNo GROUP BY studentNo;
END $$
DELIMITER ;
-- 调用存储过程并输出结果
CALL proStudentByNo21('0800001', @sName, @avg);
在MYSQL中运行上述代码即可实现SQL Server版本的存储过程在MYSQL中的运行。需要注意的是,MYSQL和SQL Server有所不同的地方,需要针对具体的问题进行相应的调整。
解决 无用评论 打赏 举报
悬赏问题
- ¥15 fluent的在模拟压强时使用希望得到一些建议
- ¥15 STM32驱动继电器
- ¥15 Windows server update services
- ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
- ¥15 模糊pid与pid仿真结果几乎一样
- ¥15 java的GUI的运用
- ¥15 Web.config连不上数据库
- ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
- ¥15 怎么配置广告联盟瀑布流
- ¥15 Rstudio 保存代码闪退