在 MySQL 中是否有替代“创建或替换过程”的方法?

ama*_*sko 23 mysql stored-procedures

MySQL 是否有“创建或替换过程”的版本?如果在重新编译之前没有收到存储过程存在的错误消息,我似乎无法执行此操作或编写删除过程的脚本(如果存在)。

DELIMITER $$

-- would love to be able to drop procedure if exists db.sp_tmp_90days;  
-- or use "create or replace"

create procedure db.sp_tmp_90days()

BEGIN
drop table db.tmp_90days;

create table db.tmp_90days ( 
    user_name varchar(128), 
    first_name varchar(50), 
    last_name varchar(50), 
    system varchar(10), 
    last_login datetime 
);

alter table db.tmp_90days add index idx_user_name(user_name);
alter table db.tmp_90days add index idx_system(system);
alter table db.tmp_90days add index idx_last_login(last_login);

insert into db.tmp_90days (user_name, first_name, last_name, system, last_login)
    SELECT
        [...]
END $$
Run Code Online (Sandbox Code Playgroud)

Roh*_*pta 27

如果它存在,这是删除它的语法

DROP PROCEDURE IF EXISTS db.sp_tmp_90days;
Run Code Online (Sandbox Code Playgroud)

  • 还可以提到 MariaDB,一个 MySQL 的“替代替代品”,从 10.1 版开始就支持`CREATE OR REPLACE PROCEDURE` 语法。 (7认同)