`
xiangxm
  • 浏览: 67149 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论
  • xiangxm: xurichusheng 写道一些涉及到密码保存的就需要加密/ ...
    3DES加密
  • xurichusheng: 一些涉及到密码保存的就需要加密/解密了。不需要解密的密码,如登 ...
    3DES加密

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



分享到:
评论

相关推荐

    SqlServer自定义多参数聚合函数实例代码

    标题提到的"SqlServer自定义多参数聚合函数实例代码"就是针对这种情况提供的一种解决方案。 自定义聚合函数通常通过两种方式实现:T-SQL(Transact-SQL)或CLR(Common Language Runtime)。T-SQL方式适用于简单的...

    sql server 自定义函数

    在SQL Server中,用户自定义函数(User-Defined Functions, UDFs)允许开发者创建能够执行特定任务并返回结果的自定义逻辑。这些函数不仅可以增强SQL Server的功能性,还能提高代码的可读性和可维护性。用户自定义函数...

    Sqlserver 自定义函数 Function使用介绍

    SQL Server中的自定义函数是数据库开发中非常重要的组成部分,它们允许开发者创建自定义的逻辑,以便在查询中重用和简化复杂操作。本篇主要关注SQL Server 2008中的三种自定义函数:标量函数、内联表值函数和多语句...

    Microsoft SQL Server 自定义函数整理大全

    Microsoft SQL Server 自定义函数整理大全是指使用 SQL Server 创建的自定义函数,以满足特定的业务需求。这些函数可以对字符串进行处理、数据转换、计算等操作。本篇文章将介绍一个自定义函数的示例,该函数用于...

    收集整理的SQL Server自定义函数

    收集整理的SQL Server自定义函数,原文地址:http://blog.csdn.net/maco_wang 1.去除字符串中的html标记及标记中的内容 2 2. 去除字符串中连续的分割符 4 3.求第一个字符串中第二个串的个数 6 4.综合模糊查询 6 5....

    SQL自定义函数的好处

    SQL自定义函数是SQL Server 2000中新增的数据库对象,它允许用户根据需要自定义函数,以满足特定的业务需求。与系统内置的函数不同,自定义函数可以根据用户的需求进行定制,满足特定的业务需求。 SQL自定义函数的...

    Sqlserver 2014 之 自定义字符串聚合函数

    下面是一个可能的`STRING_AGG`自定义函数的C#实现概述: ```csharp using System; using System.Collections.Generic; using Microsoft.SqlServer.Server; [Serializable] [SqlUserDefinedAggregate( Format.User...

    SQL自定义函数讲解

    用户自定义函数允许开发者创建自己的函数,以便在SQL查询中重复使用。创建用户自定义函数的过程包括以下几个步骤: - **创建用户自定义函数**:使用`CREATE FUNCTION`语句定义函数的输入参数、返回类型和函数体。...

    SQL Server数据库自定义函数与存储过程研究.pdf

    在 SQL Server 中,自定义函数和存储过程都可以创建捆绑 SQL 语句,并存储在服务器中供以后使用。它们可以提高工作效率,减少编程时间,允许重复使用编程代码,隐藏 SQL 细节,并实现集中化的维护。 尽管自定义函数...

    自定义函数

    下面的示例展示了如何在SQL Server中创建一个自定义函数,该函数用于根据指定的ID拼接相应的值为一个字符串。 1. **创建表**:首先,我们需要创建一个简单的测试表`tb`,其中包含两列`id`和`value`。 ```sql ...

    SQL Server自定义函数判断Email字段的有效性

    在SQL Server中,自定义函数是一种非常有用的功能,它允许我们创建自己的操作逻辑,以便在查询或存储过程中重用。本话题将详细讲解如何利用T-SQL(Transact-SQL)编写一个自定义函数来验证电子邮件(Email)字段的...

    sql自定义函数分组合并字符串列

    sql自定义函数,用于合并字符串列,可以在分组的情况下对varchar类型的字段合并

    SQL常用功能自定义函数

    自定义函数是SQL中的一个重要特性,它允许开发人员根据特定需求创建自己的函数,从而扩展SQL的功能。以下是一些从标题和描述中提取的SQL自定义函数知识点: 1. **SQL简繁转换函数**: 这个函数可能涉及到了字符集的...

    sqlserver MD5函数

    #### 三、SQL Server自定义MD5函数实现 根据提供的部分代码,可以看出作者是通过一系列的自定义函数来实现MD5加密过程的。这些函数包括但不限于: 1. **MD5**: 主要负责执行整个MD5加密过程。 2. **MD5_F**、**MD5_...

    SQL server自定义函数电子书

    SQL server自定义函数电子书

    SQLServer自定义字符串聚合函数DLL文件(可直接使用)

    http://yufeng521000.iteye.com/blog/2076607; 根据这篇BOLG的函数编译的DLL,方便大家直接使用; 里面有两个DLL分别是NET3.5,以及NET4.0,下载后根据BOLG以及数据库版本选择对应的DLL使用;

Global site tag (gtag.js) - Google Analytics