加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 类型与创建CLR存储过程不匹配

发布时间:2020-12-15 08:27:49 所属栏目:百科 来源:网络整理
导读:我在程序集中有一个方法,如下所示: namespace MyNameSpace{ public class MyClass { [Microsoft.SqlServer.Server.SqlProcedure] public static void MyMethod(SqlChars myMessage) { // Stuff here } }} 我将其编译为一个DLL并将其加载到我的SQL Server中,
我在程序集中有一个方法,如下所示:
namespace MyNameSpace
{
  public class MyClass
  {
    [Microsoft.SqlServer.Server.SqlProcedure]
    public static void MyMethod(SqlChars myMessage)
    {
       // Stuff here 
    } 
  }
}

我将其编译为一个DLL并将其加载到我的SQL Server中,如下所示:

drop assembly MyAssembly
create assembly MyAssemblyfrom 'C:ScriptsMyAssembly.dll'

一切正常.

但现在我尝试运行这个:

CREATE PROCEDURE MySproc @message nvarchar(max)
AS EXTERNAL NAME MyAssembly.[MyNameSpace.MyClass].MyMethod

当我运行时,我收到此错误:

CREATE PROCEDURE for “MySproc ” failed because T-SQL and CLR types for parameter “@myMessage” do not match.

我有什么想法可以解决这个问题?

我也试过这些方法签名:

> public static void MyMethod(string myMessage)
> public static void MyMethod([SqlFacet(MaxSize = -1)] string myMessage)

解决方法

Sql类型nvarchar映射到CLR(.Net)类型SqlString:
public static void MyMethod(SqlString myMessage)
{
    if (! myMessage.IsNull) 
    {
        String myMessageString = myMessage.ToString();
        // Do stuff
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读