期間UDF我有一個UDF計算基於一定範圍的要在表中值的分數。調用創建表
的UDF具有在創建表的過程中要應用/調用,這是在那裏我有一個小麻煩。
的UDF不得不使用情況下,當只有方法,所以我不能改變太多之上,但我敢肯定,我剛剛得到的東西有點過創建。
我不知道如果答案是已經在那裏或沒有,但我避風港;噸兩端偶然卻又如此道歉,如果這是已經回答了一些東西。
這裏是首先創建
--Create UDF
create function [dbo].[cupidscoreUDF]
(
@gender char(1),
@name varchar(15),
@dob datetime,
@weight int,
@height int,
@smoker bit,
@salary int
)
returns int
as
begin
declare @score int
-- To determine age in years
declare @Age int
select @Age = DATEDIFF(YEAR, @dob, GETDATE())
select
@score = case
when @Age between 20 and 30 then 5
when @Age between 31 and 40 then 4
when @Age between 41 and 50 then 3
when @Age > 50 then 2
else 0
end
-- To determine the height/weight ratio
declare @WeightHeight int
set @WeightHeight = @weight/@height
set
@score = @score +
case
when @WeightHeight between 20 and 25 then 1
when @WeightHeight between 25 and 30 then 3
when @WeightHeight between 30 and 35 then 4
when @WeightHeight between 35 and 40 then 2
else 0
end
-- If non-smoker add 2 points
if @smoker = 0
set @Score = @Score + 2
-- To determine score by salary
set
@score = @score +
case
when @salary < 50000 then 1
when @salary between 500001 and 60000 then 2
when @salary between 60001 and 70000 then 3
when @salary > 70000 then 4
end
return @score
end
;
的UDF現在,這裏就是我得到了創建表的進程
-- Create Member_Profile table
create table Member_Profile
(
MemberID int primary key,
Gender varchar(6),
Name varchar(50),
Dob datetime,
Weight int,
Height int,
Smoker bit,
Salary int,
Cupid as dbo.cupidscoreUDF
)
GO
insert into Member_Profile (Gender, Name, Dob, Weight, Height, Smoker, Salary) values ('Male','James',19931115, 75, 180, 0, 80000);
insert into Member_Profile (Gender, Name, Dob, Weight, Height, Smoker, Salary) values ('Female','Rosie',19870912, 45, 150, 0, 100000);
insert into Member_Profile (Gender, Name, Dob, Weight, Height, Smoker, Salary) values ('Male','Richard',19630402, 95, 168, 1, 200000);
select * from Member_Profile
的UDF需要會員的信息,然後計算他們的「丘比特'的分數,然後將其與其他所有內容一起插入表中。
使用UDF將是巨大的任何幫助
你可以試試'TRIGGER'而將數據插入表中... – Jesuraja 2014-09-01 04:48:33
您的UDF需要7個參數。我需要通過他們 – cha 2014-09-01 04:48:45