Clr静态数据Table-Valued函数

前两天Insus.NET实现一个功能《在数据库中提供只读数据http://www.cnblogs.com/insus/p/4384411.html ,在数据库中为程序提供静态数据。
它是在Clr存储过程实现。现想使用另外一种方式来解决。如果提供这些静态数需要与其它数据结合Join等,这样象前面的存储过程,有些不太好操作。那我们可以把它实现在table-valued function。

创建一个model:

再创建一个Entity:

打开SqlFunction类,编写table-valued函数:

可复制代码:

 [SqlFunction(DataAccess = DataAccessKind.None,
                FillRowMethodName = "FillRow_1A",
                TableDefinition = "Id TINYINT,Name NVARCHAR(30), [key] NVARCHAR(30)")
   ]
    public static IEnumerable Tvf_SiteInfor()
    {
        FruitEntity fe = new FruitEntity();
        return fe.GetData();
    }

    private static void FillRow_1A(object source, out SqlByte id, out SqlChars name, out SqlChars key)
    {
        Si obj = (Si)source;
        id = new SqlByte(obj.Id);
        name = new SqlChars(obj.Name);
        key = new SqlChars(obj.Key);
    }

部署至SQL:

可复制代码:

IF EXISTS (SELECT * FROM sys.objects WHERE name = ‘Tvf_SiteInfor‘)
    DROP FUNCTION Tvf_SiteInfor;
GO

IF EXISTS (SELECT * FROM sys.assemblies WHERE name = ‘FruitClr‘)
    DROP ASSEMBLY FruitClr;
GO

CREATE ASSEMBLY FruitClr
FROM ‘E:\FruitClr.dll‘
WITH PERMISSION_SET = SAFE;
GO

CREATE FUNCTION Tvf_SiteInfor()
RETURNS TABLE(
    Id TINYINT,
    [Name] NVARCHAR(30),
    [key] NVARCHAR(50)
)
AS EXTERNAL NAME [FruitClr].UserDefinedFunctions.Tvf_SiteInfor;
GO

执行结果:

时间: 2024-10-29 19:10:28

Clr静态数据Table-Valued函数的相关文章

静态数据成员和函数

静态数据成员 类是类型而不是具体的数据对象,类的对象都是该类的实例,每个类对象都具有自己的数据成员,而且是相互独立,各占内存空间.然而,程序中往往需要让类的所有对象在类的范围内共享某个数据.声明为static的类成员能够在类的范围中共享,称之为静态成员. 一.全局变量与静态数据成员 希望在同类的多个对象之间实现数据共享,可以用静态的数据成员实现. 使用静态数据成员不会破坏隐藏的原则,即保证了安全性. 二.静态数据成员特点 在每个类中只有一个拷贝,由该类的所有对象共同维护和使用静态数据成员的值对每

c++学习(三)------static数据与成员函数

疑惑: static类型成员是类的全局变量,所有类的实例都享有这个变量,或者说这个变量不属于任何一个类的实例. static类型变量可以为private,或public或其他(static数据可以被继承吗?) <<静态数据变量的初始化 静态数据变量的显示初始化: 在头文件类定义中申明,在非inline函数所在文件初始化 <<const 类型的静态变量可以用于初始化数组 <<数组不能在类体内初始化,任何试图这样做的操作都将导致错误 <<类的成员函数可以直接访问

静态数据成员与静态成员函数

静态属性不是类中每个对象拥有的,而是共有的.由于静态成员逃离了对象而存在的性质,所以该实体应该在所有对象产生之前产生,更适合的时机是在程序启动的时候做初始化.初始化时候不可重复上static,但是要加上类名空间.该实体在程序中的唯一性,要求他不可以和类的定义放在头文件中,但是它确实是类的成员,所以放在类实现中最合适.如下: //--------------------Student.h ---类定义的文件 class Student{ private: static int num; } //-

C++静态成员函数和静态数据成员

当将类的某个数据成员声明为static时,该静态数据成员只能被定义一次,而且要被同类的所有对象共享.各个对象都拥有类中每一个普通数据成员的副本,但静态数据成员只有一个实例存在,与定义了多少类对象无关.静态方法就是与该类相关的,是类的一种行为,而不是与该类的实例对象相关. 静态数据成员的用途之一是统计有多少个对象实际存在. 静态数据成员不能在类中初始化,实际上类定义只是在描述对象的蓝图,在其中指定初值是不允许的.也不能在类的构造函数中初始化该成员,因为静态数据成员为类的各个对象共享,否则每次创建一

OGG &amp;quot;Loading data from file to Replicat&amp;quot;table静态数据同步配置过程

OGG "Loading data from file to Replicat"table静态数据同步配置过程 一个.mgr过程 GGSCI (lei1) 3> view params mgr port 7809 二.抽取进程extftor GGSCI (lei1) 4> view params extftor SOURCEISTABLE userid goldengate, password yyyyy rmthost 192.168.100.189, mgrport 7

sdut 3-6 静态数据成员与静态成员函数

3-6 静态数据成员与静态成员函数 Time Limit: 1000MS Memory limit: 65536K 题目描述 通过本题目的练习可以掌握静态数据成员和静态成员函数的用法 要求设计一个点类Point,它具有两个double型的数据成员x,y.和一个静态数据成员count ,用以记录系统中创建点对象的数目.为该类设计构造函数和析构函数,在其中对count的值做修改,体现点的数目的动态变化.并为其添加一个静态成员函数用以输出count的值:成员函数showPoint()用于输出点的信息.

C++ 静态数据成员和静态成员函数

一 静态数据成员: 1.静态数据成员的定义. 静态数据成员实际上是类域中的全局变量.所以,静态数据成员的定义(初始化)不应该被放在头文件中,因为这样做会引起重复定义这样的错误.即使加上#ifndef #define #endif或者#pragma once也不行. 其定义方式与全局变量相同.举例如下: xxx.h文件 class base{ private: static const int _i;//声明,标准c++支持有序类型在类体中初始化,但vc6不支持. }; xxx.cpp文件 con

在c++中,静态数据成员可以被非静态成员函数调用吗?如果可以调用的话那为什么还要定义静态成员函数呢

静态数据成员可以被非静态成员函数访问.但静态成员函数只能访问静态数据成员.静态数据成员从属于某一个类,而不是某一个类的 对象.同理,静态成员函数也是一样. 追问 定义静态成员函数的作用有何在呢 回答 静态成员函数隶属于类,不用实例化对象,就可以直接调用静态成员函数来操作静态数据成员 提问者评价 太给力了,你的回答完美解决了我的问题!

C++静态数据成员与静态成员函数

一般情况下,如果有n个同类的对象,那么每一个对象都分别有自己的数据成员,不同对象的数据成员各自有值,互不相干.但是有时人们希望有某一个或几个数据成员为所有对象所共有,这样可以实现数据共享. 可以使用全局变量来达到共享数据的目的.例如在一个程序文件中有多个函数,每一个函数都可以改变全局变量的值,全局变量的值为各函数共享.但是用全局变量的安全性得不到保证,由于在各处都可以自由地修改全局变量的值,很有可能偶然失误,全局变量的值就被修改,导致程序的失败.因此在实际工作中很少使用全局变量. 如果想在同类的