[英]C# how to pass a DataTable parameter without a UDT to SQL Server
[英]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.SqlDbType
、 sp.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";
尝试使用以下代码,
var testingparam = command.Parameters.AddWithValue("@param3", myDataTable);
testingparam.SqlDbType = SqlDbType.Structured;
我在 SQL 管理工具中创建了用户定义的类型后使用了它。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.