繁体   English   中英

C#中的SQL UDT类型参数传递

[英]SQL UDT Type parameter pass in C#

我有一个 SQL UDT 类型作为

CREATE TYPE [dbo].[UDTName] FROM nvarchar(50) NULL
GO

我在一个过程中使用它来将数据插入到我的数据库中。 我的程序是这样的

CREATE PROCEDURE [dbo].[proc_name]
(
  @param1 int,
  @param2 int,
  @param3 UDTName,
  @param4 UDTComment,
  @param5 UDTType   = '' output,
  @param6 UDTType   = '' output
)

当我从我的 C# 代码调用此过程时,UDT 类型数据不会保存在表中。

我的 C# 代码:

  private IDictionary<string, string> RunQuery(string procName, List<Parameter> input) {
foreach (Parameter inputPair in input)
                    {
         SqlParameter sp = new SqlParameter("@" + inputPair.Name , inputPair.Type);  
                    // I have tried SQLDbType as Varchar, nVarchar also
         sp.Direction = System.Data.ParameterDirection.Input
         sp.SqlDbType = SqlDbType.Udt;
         // i have an if condition around it to check if it is UDT type only then add a UdtTypeName 
         sp.UdtTypeName = "UDTName"; // I have tried dbo.UDTName also
         sp.Size = inputPair.Size; //setting only in case of varchar
         sp.Value = inputPair.Value;

         cmd.Parameters.Add(sp);

}
  cmd.CommandType = CommandType.StoredProcedure;

                param1.ParameterName = "@param5";
                param1.SqlDbType = System.Data.SqlDbType.VarChar;
                param1.Size = 255;
                param1.Direction = System.Data.ParameterDirection.Output;
                cmd.Parameters.Add(param1);

 _reader = cmd.ExecuteReader();
}

参数类是

     public class Parameter
        {
            public string Name { get; set; }
            public object Value { get; set; }
            public object Type { get; set; }
            public bool isUDT { get; set; }
            public int Size { get; set; }
public bool UdtTypeName  { get; set; }
        }

但它没有将数据插入我的数据库并抛出以下异常:

结果消息:System.Exception:指定类型未在目标服务器上注册。System.String、mscorlib、Version=4.0.0.0、Culture=neutral、PublicKeyToken=b77a5c561934e089。

如果我在代码中使用 varchar SQLDbType 代替 UDTType SQLDbType,它会成功运行但未将数据插入表中。

我做了一些研究,但到处都有人使用表值对基本 UDT 类型。

注意:我无权更改 SQL DB 中的任何内容。

编辑

我也试过数据表

我的代码:

 DataTable dataTable = new DataTable("UDTName");
                            dataTable.Columns.Add();
                            dataTable.Rows.Add("my_value");

                            var inputParam = cmd.Parameters.AddWithValue("@param3", dataTable);
                            inputParam.SqlDbType = SqlDbType.Structured;
                            inputParam.Direction = System.Data.ParameterDirection.Input;

它显示以下错误:

结果消息:System.Exception:操作数类型冲突:表类型与 nvarchar(50) 不兼容

您需要正确指定 2 种类型( sp.SqlDbTypesp.UdtTypeName )、名称和值。

看起来您设置了错误的值或不正确的sp.UdtTypeName

检查您创建SqlParameter的方式:

SqlParameter sp = new SqlParameter("@" + inputPair.Name , inputPair.Type);

这里的问题是您的inputPair.Type是对象类型。

所以下面的构造函数被调用:

public SqlParameter( string parameterName , object value )

而不是您可能期望的另一个:

public SqlParameter( string parameterName , SqlDbType dbType )

你的代码应该是这样的:

SqlParameter sp = new SqlParameter("@" + inputPair.Name , value);
sp.SqlDbType = SqlDbType.Udt;
sp.UdtTypeName = "UDTName";

https://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlparameter.udttypename(v=vs.90).aspx

尝试使用以下代码,

var testingparam = command.Parameters.AddWithValue("@param3", myDataTable);
testingparam.SqlDbType = SqlDbType.Structured;

我在 SQL 管理工具中创建了用户定义的类型后使用了它。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM