什么都不懂的菜鸟玩家 2018-12-30 17:54 采纳率: 50%
浏览 390

如何把以下SQLServer版本的存储过程改为MYSQL版本?

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版本并运行
(萌新,求教,求救大佬)

  • 写回答

1条回答

  • lshen01 2023-03-15 18:26
    关注

    参考GPT和自己的思路:

    可以把SQL Server版本的存储过程改为MYSQL版本的,需要进行以下步骤:

    1. 修改存储过程的名称,以符合MYSQL的要求。

    2. 修改存储过程的参数类型和声明方式。MYSQL使用不同的数据类型和参数声明方式,需要进行相应修改。

    3. 修改存储过程的SQL语句,以符合MYSQL的要求。MYSQL对SQL语句语法和关键字的要求与SQL Server有所不同,需要进行适当的调整。

    4. 在MYSQL中创建相应的数据库和表,以便存储过程可以正确地执行。

    针对上述SQL Server版本的存储过程,可以按照以下方式改为MYSQL版本:

    DELIMITER $$

    CREATE PROCEDURE proStudentByNo21(IN sNo CHAR(7), OUT sName VARCHAR(20), OUT avg DOUBLE)
    BEGIN

    SELECT studentName INTO sName FROM Student WHERE studentNo = sNo;

    SELECT AVG(score) INTO avg FROM Score WHERE studentNo = sNo GROUP BY studentNo;

    END $$

    DELIMITER ;

    -- 调用存储过程并输出结果

    SET @sName = '';
    SET @avg = 0;

    CALL proStudentByNo21('0800001', @sName, @avg);

    SELECT @sName, @avg;

    在MYSQL中运行上述代码即可实现SQL Server版本的存储过程在MYSQL中的运行。需要注意的是,MYSQL和SQL Server有所不同的地方,需要针对具体的问题进行相应的调整。

    评论

报告相同问题?

悬赏问题

  • ¥15 Matlab怎么求解含参的二重积分?
  • ¥15 苹果手机突然连不上wifi了?
  • ¥15 cgictest.cgi文件无法访问
  • ¥20 删除和修改功能无法调用
  • ¥15 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题
  • ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档