Есть ли альтернатива «Создать или заменить процедуру» в MySQL?

Есть ли версия 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 $$
12 голосов | спросил amatusko 15 Jam1000000amFri, 15 Jan 2016 02:56:54 +030016 2016, 02:56:54

1 ответ


14

Это синтаксис, чтобы удалить его, если он существует

DROP PROCEDURE IF EXISTS db.sp_tmp_90days;
ответил Rohit Gupta 15 Jam1000000amFri, 15 Jan 2016 03:31:08 +030016 2016, 03:31:08

Похожие вопросы

Популярные теги

security × 330linux × 316macos × 2827 × 268performance × 244command-line × 241sql-server × 235joomla-3.x × 222java × 189c++ × 186windows × 180cisco × 168bash × 158c# × 142gmail × 139arduino-uno × 139javascript × 134ssh × 133seo × 132mysql × 132