Пожалуйста, помните, что текстовый столбец в syscomments - это varchar (255), поэтому одна большая процедура может состоять из многих строк в syscomments, поэтому при выборе выше не будет найдено имя процедуры, если она разбита на 2 строки syscomments.
Я предлагаю следующий выбор, который будет обрабатывать вышеуказанный случай:
declare @text varchar(100)
select @text = "%whatever%"
select distinct o.name object
from sysobjects o,
syscomments c
where o.id=c.id
and o.type='P'
and (c.text like @text
or exists(
select 1 from syscomments c2
where c.id=c2.id
and c.colid+1=c2.colid
and right(c.text,100)+ substring(c2.text, 1, 100) like @text
)
)
order by 1
- благодарность за это идет создателю ASEisql