sql server 创建自定义函数


--is中文字符串(判断是否为汉字)
create function is中文字符串(@字符串 nchar(255))
returns nchar(1) as
begin
declare @I tinyint, @J tinyint
set @I=len(@字符串)
set @J=1
while (@J<=@I)
begin
if (unicode(substring(@字符串,@J,1))<256) return '否'
set @J=@J+1
end
return '是'
end
GO

create function is学院信息表编号(@字符串 char(4))
returns nchar(1) as
begin
if exists(select *from 学院信息表 where 编号=left(@字符串,2))
return '是'

return '否'
end
go

create function is系部信息表编号(@字符串 char(6))
returns nchar(1) as
begin
if exists(select *from 系部信息表 where 编号=left(@字符串,4))
return '是'

return '否'
end
go



下面部分适合sqlserver 2008 之前版本会报错。
和前面的是一样的功能。

--规则:4位字符,前2位为所属学院编号
create function check系部编号(@inputID varchar(30)) returns nchar(1) as begin

declare @out nchar='否';
if substring(@inputID,1,2) in(select 编号 from dbo.学院信息表)
set @out='是';
return @out;
end


--规则:6位字符,前4位为所属系部编号
create function check教研室编号(@inputID varchar(30)) returns nchar(1) as begin

declare @out nchar='否';
if substring(@inputID,1,4) in(select 编号 from dbo.系部信息表)
set @out='是';
return @out;
end

create function check检查班级课程表编号(@inputID varchar(500)) returns nchar(1) as begin


--规则:班级编号+教师编号+课程编号 不能重复

declare @inputStr varchar(500)=@inputID;
declare @temp1 varchar(8)=substring(@inputStr,1,8);
declare @temp2 varchar(6)=substring(@inputStr,9,14);
declare @temp3 varchar(6)=substring(@inputStr,15,20);
declare @out nchar(1)='否';

if @temp1 in (select 编号 from 班级信息表) and @temp2 in(select 编号 from 教师信息表) and @temp3 in(select 编号 from 课程信息表)
set @out='是';


return @out;
end


create function check教学成绩编号(@inputID char(18)) returns nchar(1) as begin


--规则:学号(6)+教师编号(6)+课程编号(6),不能重复

declare @inputStr varchar(50)=@inputID;
declare @temp1 varchar(6)=substring(@inputStr,1,6);
declare @temp2 varchar(6)=substring(@inputStr,7,12);
declare @temp3 varchar(6)=substring(@inputStr,13,18);
declare @out nchar(1)='否';

if @temp1 in (select 学号 from 学生信息表) and @temp2 in(select 编号 from 教师信息表) and @temp3 in(select 编号 from 课程信息表)
set @out='是';


return @out;
end

--规则:4位字符,前2位为所属学院编号
create function check系部编号(@inputID varchar(30)) returns nchar(1) as begin

declare @out nchar='否';
if substring(@inputID,1,2) in(select 编号 from dbo.学院信息表)
set @out='是';
return @out;
end


--规则:6位字符,前4位为所属系部编号
create function check教研室编号(@inputID varchar(30)) returns nchar(1) as begin

declare @out nchar='否';
if substring(@inputID,1,4) in(select 编号 from dbo.系部信息表)
set @out='是';
return @out;
end

create function check检查班级课程表编号(@inputID varchar(500)) returns nchar(1) as begin


--规则:班级编号+教师编号+课程编号 不能重复

declare @inputStr varchar(500)=@inputID;
declare @temp1 varchar(8)=substring(@inputStr,1,8);
declare @temp2 varchar(6)=substring(@inputStr,9,14);
declare @temp3 varchar(6)=substring(@inputStr,15,20);
declare @out nchar(1)='否';

if @temp1 in (select 编号 from 班级信息表) and @temp2 in(select 编号 from 教师信息表) and @temp3 in(select 编号 from 课程信息表)
set @out='是';


return @out;
end


create function check教学成绩编号(@inputID char(18)) returns nchar(1) as begin


--规则:学号(6)+教师编号(6)+课程编号(6),不能重复

declare @inputStr varchar(50)=@inputID;
declare @temp1 varchar(6)=substring(@inputStr,1,6);
declare @temp2 varchar(6)=substring(@inputStr,7,12);
declare @temp3 varchar(6)=substring(@inputStr,13,18);
declare @out nchar(1)='否';

if @temp1 in (select 学号 from 学生信息表) and @temp2 in(select 编号 from 教师信息表) and @temp3 in(select 编号 from 课程信息表)
set @out='是';


return @out;
end

create function isChinese(@input varchar(8000)) returns nchar(1) as
begin
declare @out nchar(1)='是';
declare @index int=0;
declare @tempStr nchar(1);

while @index<=len(@input)
begin
set @tempStr=substring(@input,@index,@index+2);
if unicode(@tempStr)<19968 or unicode(@tempStr)>40869
begin
set @out='否';
break;
end

else
begin
set @index=@index+1;
end

end

return @out

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值