数据库函数

一、函数创建
SQL SERVER:

“自定义函数”是我们平常的说法,而“用户定义的函数”是 SQL Server 中书面的说法。

SQL Server 2000 允许用户创建自定义函数,自定义函数可以有返回值。

自定义函数分为:标量值函数或表值函数

如果 RETURNS 子句指定一种标量数据类型,则函数为标量值函数。可以使用多条 Transact-SQL 语句定义标量值函数。
如果 RETURNS 子句指定 TABLE,则函数为表值函数。
表值函数又可分为:内嵌表值函数(行内函数)或多语句函数

如果 RETURNS 子句指定的 TABLE 不附带列的列表,则该函数为内嵌表值函数。
如果 RETURNS 子句指定的 TABLE 类型带有列及其数据类型,则该函数是多语句表值函数。

1.标量值函数示例

create function getWorkerWelfare(@welfareid varchar(60), @absentsum varchar(10), @daymoney varchar(10), @type varchar(40))
returns decimal(7, 2)
as
begin
	--declare @welfareid varchar(60)
	--declare @absentsum varchar(10)
	--declare @daymoney varchar(10)
	--declare @type varchar(40)
	--set @welfareid = 'EB2011021212973401863681954589888'
	--set @absentsum = '0.5'
	--set @daymoney = '80'
	--set @type = '勤杂人员'

	--创建补贴标准游标
	declare cur_allo cursor for
	select absentbegin, absentend, laborallowance, medicalallowance, attendallowance
	from t_worker_allowance_standard 
	--where groupid = (select workerallowancegroupid from t_worker_welfare_standard where id = @welfareid) 
	where groupid = (select workerallowancegroupid from t_worker_welfare_standard where id = @welfareid) 
	
	--创建工人类型标准游标
	declare cur_type cursor for
	select monetizebegin, monetizeend, workertype, attendallowanceper
	from t_worker_type_standard 
	--where groupid = (select workertypegroupid from t_worker_welfare_standard where id = @welfareid) 
	where groupid = (select workertypegroupid from t_worker_welfare_standard where id = @welfareid) 

	declare @absentbegin varchar(10)
	declare @absentend varchar(10)
	declare @laborallowance varchar(10)
	declare @medicalallowance varchar(10)
	declare @attendallowance varchar(10)
	
	declare @monetizebegin varchar(10)
	declare @monetizeend varchar(10)
	declare @workertype varchar(40)
	declare @attendallowanceper varchar(10)
	
	declare @welfare decimal(7, 2)
	set @welfare = 0
	
	open cur_allo
	open cur_type
	fetch next from cur_allo into @absentbegin, @absentend, @laborallowance, @medicalallowance, @attendallowance
	while @@fetch_status = 0
	begin
		if @@fetch_status = -2	continue
		if @absentbegin = '#' set @absentbegin = '-1'
		if @absentend = '#' set @absentend = '9999999999'
		if cast(@absentsum as numeric(7, 2)) >= cast(@absentbegin as numeric(12, 2)) and cast(@absentsum as numeric(7,2)) < cast(@absentend as numeric(12, 2))
		begin
			--print('出勤区间:' + @absentbegin + '---' + @absentend);
			fetch next from cur_type into @monetizebegin, @monetizeend, @workertype, @attendallowanceper
			while @@fetch_status = 0
			begin
				if @monetizebegin = '#' set @monetizebegin = '-1'
				if @monetizeend = '#' set @monetizeend = '9999999999'
				if patindex('%' + @type + '%', @workertype) > 0 and cast(@daymoney as numeric(7, 2)) >= cast(@monetizebegin as numeric(12, 2)) and cast(@daymoney as numeric(7, 2)) < cast(@monetizeend as numeric(12, 2))
				begin
					--print('货币化工资区间:' + @monetizebegin + '-' + @monetizeend)
					set @welfare = cast(@laborallowance as numeric(7, 2)) + cast(@medicalallowance as numeric(7, 2)) + cast(@attendallowance as numeric(7, 2)) * cast(@attendallowanceper as numeric(7,2)) / 100
					--print('福利工资:' + cast(@welfare as varchar(20)))
				end
				--print('货币化区间:' + @monetizebegin + '---' + @monetizeend)
				fetch next from cur_type into @monetizebegin, @monetizeend, @workertype, @attendallowanceper
			end
		end
		fetch next from cur_allo into @absentbegin, @absentend, @laborallowance, @medicalallowance, @attendallowance
	end
	close cur_allo
	close cur_type
	deallocate cur_allo
	deallocate cur_type

	return @welfare
end


2.内嵌表值函数示例

CREATE FUNCTION dbo.Foo()
RETURNS TABLE
AS  
    return select id, title from msgs
--内嵌表值函数只有一个 select 语句。


3.多语句表值函数示例(部分)

CREATE FUNCTION fn_FindReports (@InEmpId nchar(5))
RETURNS @retFindReports TABLE (empid nchar(5) primary key,
   empname nvarchar(50) NOT NULL,
   mgrid nchar(5),
   title nvarchar(30))
...
--注意其 RETURNS 部分。

多语句函数标量值函数的主体中允许使用以下语句。未在下面的列表中列出的语句不能用在函数主体中。

1).赋值语句。
2).控制流语句。
3).DECLARE 语句,该语句定义函数局部的数据变量和游标。
4).SELECT 语句,该语句包含带有表达式的选择列表,其中的表达式将值赋予函数的局部变量。
5).游标操作,该操作引用在函数中声明、打开、关闭和释放的局部游标。只允许使用以 INTO 子句向局部变量赋值的 FETCH 语句;不允许使用将数据返回到客户端的 FETCH 语句。
6).INSERT、UPDATE 和 DELETE 语句,这些语句修改函数的局部 table 变量。
7).EXECUTE 语句调用扩展存储过程。

你可能感兴趣的:(sql,SQL Server,化工)