Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.07.06;
Скачать: CL | DM;

Вниз

Rename table в хранимой процедуре   Найти похожие ветки 

 
Квэнди ©   (2008-01-27 14:20) [0]

Здравствуйте. Я хочу из хранимой процедуры переименовывать таблицы, делаю так:
create procedure renpref ()
begin
declare str varchar (50);
declare strnew varchar (50);
declare is_end INT Default 0;
declare curtab cursor for show tables;
declare continue handler for not found set is_end=1;
open curtab;
wet: LOOP
fetch curtab into str;
if is_end then LEAVE wet;
END IF;
set strnew = insert(str,1,instr(str,"_"),"tst_");
Rename table @str  to @strnew;
END LOOP wet;
CLOSE curtab;
end;

ну собственно здесь при попытке создания процедуры возникает сразу ошибка синтаксиса:
Rename table @str  to @strnew;
а можно ли как- нибудь подставить в RENAME TABLE значение переменной ? и если можно то как выйти из этой ситуации ?
СУБД MYSQL


 
MsGuns ©   (2008-01-28 10:46) [1]

Не следует бе крайней надобности переименовывать таблицы в БД, а уж закладывать это в бизнес-логику - устраивать себе маленький термоядерный взрывчик ;)


 
Sergey13 ©   (2008-01-28 10:57) [2]

> [0] Квэнди ©   (27.01.08 14:20)

Не знаю как мускуле, но некоторые сервера вообще не дают возможности менять метаданные в ХП. Обойти это можно только через динамический SQL. А вот надо ли обходить, см [1].


 
ANB ©   (2008-01-28 11:47) [3]


> Обойти это можно только через динамический SQL

А если старая таблица (оракл) еще и используется в этой же хранимке, то результат обхода через динамический скл будет совсем веселым :)


 
Sergey13 ©   (2008-01-28 11:53) [4]

> [3] ANB ©   (28.01.08 11:47)

Да много на чего можно нарваться.


 
Petr V. Abramov ©   (2008-01-28 13:37) [5]


> ANB ©   (28.01.08 11:47) [3]

так неинтересно, лучше, когда хранимка в пакете, а пакет ссылается на таблицу
:)


 
ANB ©   (2008-01-28 14:07) [6]


> так неинтересно, лучше, когда хранимка в пакете, а пакет
> ссылается на таблицу

дадад. и пакет этот называется типа коммон и его юзает 80% других пакетов и хранимок, а также все триггера и вьюхи. :)



Страницы: 1 вся ветка

Текущий архив: 2008.07.06;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.018 c
3-1201092826
IntruderLab
2008-01-23 15:53
2008.07.06
MSSQL инструкция IN


2-1213015398
tytus
2008-06-09 16:43
2008.07.06
Как в TIdTelnet передать несколько комманд?


2-1213005331
Zabludshiy
2008-06-09 13:55
2008.07.06
Проблема с выполнением запроса в ADOquery


2-1212663474
msg
2008-06-05 14:57
2008.07.06
обработка сообщений и наследование


6-1189759827
horny
2007-09-14 12:50
2008.07.06
Share - ресурсы