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);
    }
View Code


部署至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
View Code


执行结果:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值