当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-05-02 15:21:00  来源:本站整理

UDF—SQL Server 2000的新特点[MSSQL防范]

赞助商链接



  本文“UDF—SQL Server 2000的新特点[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
本文将介绍Microsoft sql server 2000的新增特点—用户自定义函数User-Defined Function(UDF),并演示几个常用的实例.
  UDF的功效近似SQL Server中内建的系统函数,如CONVERT、SUBSTRING、 DATAADD、 GETDATA、ISNULL等等.一个UDF可以没有参数,大概带有一个或多个参数,函数运行后将会返回一个函数值.定义UDF的语法以下:

CREATE FUNCTION [ owner_name.] function_name

( { { @parameter_name scalar_parameter_data_type

[,…n] ] )

RETURN scalar_return_data_type

[WITH < function_option> [, … n]]

[AS]

BEGIN

Function_body

RETURN scalar_expression

END

每个UDF可以带有0个到1024个参数,每个参数可以是除了timestamp、cursor、table 以外全部的数据范例;函数返回值的限制要更多一些,它不可以是text、ntext、image、timestamp、cursor和table.

函数体是UDF的主要部份,它有两个选项: ENCRYOTION和 SCHEMABINDING.

SCHEMABINDING是SQL Server 2000的新增功效,可以和视图一同利用.该选项不答应删除和改正被该函数引用的对象.这样可以避免无效的函数和视图对它们引用的对象举行构造上的改正.

大家会注意到函数体以Begin开始,End完毕.这一点差别于成立存储历程、触发器和视图.当您忘了写上Begin/End时,系统会返回一个提醒信息"Incorrect syntax near ‘RETURN’".为什么不直接说少了Begin/End,这有点让人费解.




下面我用几个例子来阐明UDF的利用.

Greatest and Least

  为了辨别于系统函数Max和Min,我给新函数命名为Greatest和Least,它们会从以参数情势输入的两个值中找出最大值和最小值.

Case语句是两个函数的核心:

CASE WHEN value1 > value2 THEN value1 ELSE value2 END

固然函数很简单,但用处是很广的.

CREATE FUNCTION dbo.Greatest

-- Return the maximum of two parameters

(@Val1 SQL_VARIANT,

@Val2 SQL_VARIANT)

RETURNS SQL_VARIANT

AS

BEGIN

RETURN (CASE WHEN @val1 > @val2 THEN @val1 ELSE @val2 END)

END

go

―――――――――――――――――――――――――――――――



CREATE FUNCTION dbo.Least

-- Return the minimum of two parameters

( @val1 SQL_VARIANT,

@val2 SQL_VARIANT )

RETURNS SQL_VARIANT

AS

BEGIN

RETURN (CASE WHEN @val1 < @val2 THEN @val1 ELSE @val2 END)

END

Go

大小写转换函数

该函数有两个参数:@String和@Capitalize_What.

根据 @Capitalize_What的值,函数有差别的功效:

¨ @Capitalize_What = ‘string’"

函数将 @string的第一个非空字符转换成大写, 别的部份改成小写.

¨ @Capitalize_What = ‘sentence’

函数将 @string中的每一句的首个非空字符转换为大写,句子别的部份转换为小写.断句的根据是’.’、’!’、’?’

¨ @Capitalize_What = ‘word’

函数将 @string中的每个词都转换成首字符大写,别的小写的情势.



CREATE FUNCTION dbo.Capitalize (

-- Capitalize the first character of every word,

-- sentence, or the whole string. Put the rest to lowercase.

@String VARCHAR (8000),

@Capitalize_What VARCHAR (8) = ’string’

-- String: Capitalize the first letter of the string



-- Sentence: Capitalize the first letter of every sentence.

-- Delimiters: ./!/?



-- Word: Capitalize the first letter of every word.

-- Delimiters: any characters other than letters and digits.

)

RETURNS VARCHAR(8000)

AS

BEGIN

DECLARE @Position SMALLINT,

@Char CHAR(1),

@First_Char CHAR (1),

@Word_Start SMALLINT



SET @Capitalize_What = LOWER( @Capitalize_What )

SET @Word_Start = 0

IF @Capitalize_What IN (‘word’, ‘sentence’)

BEGIN

SET @Position = DATALENGTH( @String )

WHILE @Position >= 0 BEGIN

SET @Char = CASE @Position

WHEN 0 THEN ’.’

ELSE UPPER( SUBSTRING(

@String, @Position,

1 ) )

END

IF @Char BETWEEN ’A’ AND ’Z’

OR @Char BETWEEN ’0’ and ’9’ BEGIN

SET @Word_Start = @Position

SET @First_Char = UPPER( @Char )

END

ELSE BEGIN

IF @Capitalize_What = ’word’

OR @Char in ( ’.’, ’!’, ’?’ ) BEGIN

IF @Word_Start > 0

AND @First_Char BETWEEN ’A’

AND ’Z’

SET @String = STUFF(

@String, @Word_Start,

1, @First_Char )

SET @Word_Start = 0

END

END

SET @Position = @Position - 1

END

END

ELSE BEGIN -- Capitalize the first character

SET @Position = 0

WHILE @Position < DATALENGTH( @String )

BEGIN

SET @Position = @Position + 1

SET @Char = UPPER( SUBSTRING( @String,

@Position, 1 ) )

IF @Char BETWEEN ’A’ AND ’Z’

OR @Char BETWEEN ’0’ AND ’9’ BEGIN

SET @String = STUFF( @String,

@Position, 1, @Char )

SET @Position = 9999

END

END

END

RETURN( @String )

END

go



小结

SQL Server 2000 的 UDF的利用是很遍及的,它会给编程人员带来极大的便利.您可以成立自己的’system’ UDF,存在Master数据库中,可认为任何数据库举行调用.

UDF也有不足,我们知道系统函数可以肆意调有,不管您利用大写、小写大概大小写混合.UDF却不行,它是大小写敏感的.

在将来的版本中,我但愿微软为UDF增添默许值的功效,今后我们可以这样定义一个函数.

CREAT FUNCTION dbo.Test_default

( @parm int = 0 )

RETURN INT

AS

BEGIN

RETURN ( @parm )

END



UDF中诸如此类的小问题还有不少,但愿UDF的功效越来越强盛,我们编程人员工作起来就会越来越轻松.
  以上是“UDF—SQL Server 2000的新特点[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>MySQL UDF调试方法debugview</b>
  • UDF在层次型数据处理中的妙用之一
  • UDF在层次型数据处理中的妙用之二
  • UDF在层次型数据处理中的妙用之三
  • UDF在层次型数据处理中的妙用之四
  • UDF在层次型数据处理中的妙用之五
  • UDF—SQL Server 2000的新特点
  • <b>若何操纵Debugview方法来调试MySQL UDF</b>
  • MYSQL中的UDF - Can't open shared library 的研究
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .