你可以用视图代替它: create view view1 as select rand() as randvalue CREATE function funcMakeRandString() returns char(8) as begin declare @sz varchar(8) declare @i int
set @sz='' set @i=0 while @i<8 begin select @sz=@sz + convert(char(1),convert(int,(9*(select randvalue from view1)+1))) select @i=@i+1 end return @sz end
函数可以是确定的或不确定的。如果任何时候用一组特定的输入值调用函数时返回的结果总是相同的,则这些函数为确定的。如果每次调用函数时即使用的是相同的一组特定输入值,返回的结果总是不同的,则这些函数为不确定的。不确定的函数会产生副作用。副作用是更改数据库的某些全局状态,比如更新数据库表或某些外部资源,如文件或网络等(例如,修改文件或发送电子邮件消息)。不允许在用户定义函数主体中内置不确定函数;这些不确定函数如下:@@CONNECTIONS @@TOTAL_ERRORS
@@CPU_BUSY @@TOTAL_READ
@@IDLE @@TOTAL_WRITE
@@IO_BUSY GETDATE
@@MAX_CONNECTIONS GETUTCDATE
@@PACK_RECEIVED NEWID
@@PACK_SENT RAND
@@PACKET_ERRORS TEXTPTR
@@TIMETICKS
尽管在用户定义函数主体中不允许有不确定函数,这些用户定义函数在调用扩展存储过程时仍会产生副作用。由于扩展存储过程会对数据库产生副作用,因此调用扩展存储过程的函数是不确定的。当用户定义函数调用会对数据库产生副作用的扩展存储过程时,不要指望结果集保持一致或执行函数。
create view view1 as
select rand() as randvalue
CREATE function funcMakeRandString()
returns char(8)
as
begin
declare @sz varchar(8)
declare @i int
set @sz=''
set @i=0
while @i<8
begin
select @sz=@sz + convert(char(1),convert(int,(9*(select randvalue from view1)+1)))
select @i=@i+1
end
return @sz
end
73959638
这样的函数还有好多,如@@ERROR,GETDATE等等!
不确定函数是不相同的输入条件下每次都返回不同的值!
如:@@error,@@identity,@@rowcount,indet_incr,ident_seed,datename,newid,
等等!
但是我们可以调用它!
如:
use northwind
go
create proc aa(@indate datetime,
@separator char(1))
return nchar(20)
as
begin
convert(nvarchar(20),datepart(mm,@indate))
+@searator
+convert(nvarchar(20),datepart(dd,@indate))
+@searator
+convert(nvarchar(20),datepart(yy,@indate))
+@searator
end语句好像有点错误:)