Re: Как распечатать все хранимые процедуры в БД?

From
Victor Wagner (2:5020/400)
To
"Vit Karetny"
Date
2006-04-03T14:25:54Z
Area
SU.DBMS.SQL
From: vitus@45.free.net (Victor Wagner)

Vit Karetny <lgb@repco.ru> wrote:
VK>Милостивые государи и милостивые государыни! Надо
VK>распечатать все хранимые процедуры из БД, желательно в
VK>текстовый файл накатом. Подскажите, как это сделать? 
VK>На сем позвольте закончить, примите уверения в

В большинстве SQL-серверов тексты хранимых процедур хранятся в служебной
таблице. Так можно сделать просто запрос к этой таблице и сохранить его
результат в текстовый файл. Как правило, запрос бывает не совсем
тривиальный, потому что тексты живут отдельно, а названия, параметры и
т.д - отдельно. 

Поэтому для более точной подсказке желательно указать тип используемого
SQL сервера и версию.

В комплект многих SQL-серверов входят утилиты резервного копирования,
которые сохраняют в частности и хранимые процедуры, причем в виде
пригодном для непосредственной загрузки в базу. Например у PostgreSQL
есть утилита pg_dump у которой есть полезный ключик -s (shema-only).

Кроме того, извлекать тексты хранимых процедур из базы умеют различне
case-средства вроде ERWin.

-- 
--- ifmail v.2.15dev5.3
 * Origin: Free Net of Leninsky,45 (2:5020/400)
SEEN-BY: 46/50 50/12 203 450/159 186 1024 451/30 454/9 461/43 132 640 469/999
SEEN-BY: 4614/20 4616/3 4625/8 4627/10 4641/444 5000/76 5000 5001/5001 5006/1
SEEN-BY: 5007/1 5010/53 70 5011/13 5012/23 46 5015/28 5019/31 5020/86 175 194
SEEN-BY: 5020/400 545 604 639 715 758 830 892 982 1042 1057 1200 1523 1604
SEEN-BY: 5020/1665 1909 1922 2013 2020 2238 4441 5021/3 29 5022/128 5025/3 750
SEEN-BY: 5026/10 14 45 5027/12 5029/32 5030/115 217 436 473 556 966 1063 1339
SEEN-BY: 5030/1900 5034/13 5035/38 5036/1 5040/47 5042/13 5045/7 5047/47
SEEN-BY: 5049/1 5051/15 5053/16 5054/1 8 9 28 35 37 45 63 67 5055/95 5057/1
SEEN-BY: 5059/9 5060/88 5061/15 5062/1 5066/18 5070/1222 5077/70 5080/68 1003
SEEN-BY: 5082/6 5083/21 5084/32 5085/13 5090/106 5093/27 5095/20 5096/18
SEEN-BY: 5099/133 6000/0 1 12 6009/1
PATH: 5020/400 4441 545 5054/1 37