2006-10-08

探讨SQL Server 2005.NET CLR编程

来源: 动态网站制作指南 作者:佚名 评论 0 条
 --为运行你的工程,请编辑你的工程的test.sql文件。
--这个文件位于Solution Explorer的"Test Scripts"文件夹下
--exec IncSalaries 50
select dbo.getNetSalary(empno) from sample.dbo.emp
  按F5执行该函数,你应该能够看到相应结果。
  六. 定义.NET CLR用户定义聚合器

  现在,我们开始在上一节基础上在我们的现有方案上添加一个聚合函数。

  · 使用"Solution explorer",右击"SampleAllInOne"工程并转到"Add->Aggregate"(以创建一个新的聚合函数)(图16)。


图16

  · 之后,出现"Add New Item"对话框。在该对话框内,选择"Aggregate"作为模板,输入名字"NetSal"并点击"Add"(图17)。


图17

  一旦创建"NetSal.vb",接下来以下列方式修改你的代码:

Imports System
Imports System.Data
Imports System.Data.SqlClient
Imports System.Data.SqlTypes
Imports Microsoft.SqlServer.Server
<Serializable()> _
<Microsoft.SqlServer.Server.SqlUserDefinedAggregate(Format.Native)> _
PublicStructure NetSal
Public SumNetSal As SqlDouble
Public Sub Init()
'在此加入你的代码
SumNetSal = 0
End Sub
Public Sub Accumulate(ByVal value As SqlDouble)
 '在此加入你的代码
 Dim sal As Double = CType(value, Double)
 Dim hra As Double = sal * 10 / 100
 Dim ta As Double = 200
 Dim gross As Double = sal hra ta
 Dim epf As Double = sal * 5 / 100
 Dim net As Double = gross - epf
 SumNetSal = net
End Sub
Public Sub Merge(ByVal obj As NetSal)
 '在此加入你的代码
 SumNetSal = obj.SumNetSal
End Sub
Public Function Terminate() As SqlDouble
 '在此加入你的代码
 Return SumNetSal
End Function
EndStructure

  为了测试上面的存储过程,遵循下列步骤:

  · 使用"Solution Explorer",然后在"test scripts"中打开"test.sql"。

  · 转到最后一行并修改如下代码:

--为运行你的工程,请编辑你的工程的test.sql文件。
--这个文件位于Solution Explorer的"Test Scripts"文件夹下
--exec IncSalaries 50
--select dbo.getNetSalary(empno) from sample.dbo.emp
select dbo.NetSal(sal) from sample.dbo.emp

  按F5执行该函数,你应该能够观察到相应的结果。
共4页: 上一页 [1] [2] [3] 4 下一页
(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:Sql Server 2000数据库日志日益庞大的解决方法  
下一篇:使SQL Server数据支持 XML
    评论加载中…
 推荐文章
     

网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号