В сценариях у вас есть больше возможностей и лучший способ рационального разложения. Посмотрите на режим SQLCMD (меню запросов -> режим SQLCMD), в частности команды: setvar и: r.
В рамках хранимой процедуры ваши параметры очень ограничены. Вы не можете создать определение функции непосредственно с телом процедуры. Лучшее, что вы можете сделать, это что-то вроде этого с динамическим SQL:
create proc DoStuff
as begin
declare @sql nvarchar(max)
/*
define function here, within a string
note the underscore prefix, a good convention for user-defined temporary objects
*/
set @sql = '
create function dbo._object_name_twopart (@object_id int)
returns nvarchar(517) as
begin
return
quotename(object_schema_name(@object_id))+N''.''+
quotename(object_name(@object_id))
end
'
/*
create the function by executing the string, with a conditional object drop upfront
*/
if object_id('dbo._object_name_twopart') is not null drop function _object_name_twopart
exec (@sql)
/*
use the function in a query
*/
select object_id, dbo._object_name_twopart(object_id)
from sys.objects
where type = 'U'
/*
clean up
*/
drop function _object_name_twopart
end
go
Это приблизительно глобальная временная функция, если такая вещь существовала. Это все еще видно другим пользователям. Вы можете добавить @@ SPID вашего соединения, чтобы уникально назвать имя, но для этого потребуется, чтобы остальная часть процедуры также использовала динамический SQL.