我想使用预准备语句将一些数据插入SQL Server数据库。
我想要的查询是:
INSERT INTO salesdata([OriginalFilename], [InterchangeReceiverID], [Distributor],
[DE_Date], [DE_VendorNR], [DE_VendorDEANR], [DE_VendorName],
[DE_DistributionCenterNR], [DE_DistributionCenterID],
[DE_DistributionCenterName], [DE_ItemNR],[DE_ItemNDCNR], [DE_ProductUOM],
[DE_CustomerAccountNR], [DE_CustomerDEANR], [DE_CustomerNPINR],
[DE_CustomerHINNR], [DE_CustomerName], [DE_CustomerAddress1],
[DE_CustomerAddress2], [DE_CustomerCity], [DE_CustomerState],
[DE_CustomerZipcode], [DE_CustomerCountry], [DE_InvoiceNR], [DE_Invoicedate],
[DE_QuantitySold], [DE_QuantityReturned], [DE_SalesReturnCode],
[DE_ContractNR], [DE_Price])
VALUES(@OriginalFilename, @InterchangeReceiverID, @Distributor,
@DE_Date, @DE_VendorNR, @DE_VendorDEANR, @DE_VendorName,
@DE_DistributionCenterNR, @DE_DistributionCenterID,
@DE_DistributionCenterName, @DE_ItemNR, @DE_ItemNDCNR, @DE_ProductUOM,
@DE_CustomerAccountNR, @DE_CustomerDEANR, @DE_CustomerNPINR,
@DE_CustomerHINNR, @DE_CustomerName, @DE_CustomerAddress1,
@DE_CustomerAddress2, @DE_CustomerCity, @DE_CustomerState,
@DE_CustomerZipcode, @DE_CustomerCountry, @DE_InvoiceNR, @DE_Invoicedate,
@DE_QuantitySold, @DE_QuantityReturned, @DE_SalesReturnCode,
@DE_ContractNR, @DE_Price)
我循环遍历所有参数:
command.Parameters.Add(new SqlParameter("@InterchangeReceiverID", SqlDbType.NVarChar,500));
command.Parameters["@InterchangeReceiverID"].Value = "VALUEGOESHERE";
我也尝试了Parameters.Add(name,value)
方法,但已弃用。
我不断得到的错误是:
System.InvalidOperationException:SqlCommand.Prepare方法要求所有参数都具有明确设置的类型。
不幸的是,他没有提到导致问题的参数。我使用尺寸为500的NVarchar和尺寸为18且比例为6的小数。
我做错了什么,或者我怎样才能找出导致问题的参数?我将所有参数写入文件(具有大小/比例和值),所有这些参数看起来都不错......
完整代码:
SqlCommand command = GetNewSQLCommand(SALESDATAQRY);
//command.CommandText = SALESDATAQRY;
logger.Info(command.CommandText);
command.Parameters.Add(new SqlParameter("@InterchangeReceiverID", SqlDbType.NVarChar,500));
command.Parameters["@InterchangeReceiverID"].Value = obj.INTERCHANGE.INTERCHANGE_HEADER.INTERCHANGE_RECEIVER_ID;
command.Parameters.Add(new SqlParameter("@DE_VendorNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_VendorNR"].Value= obj.INTERCHANGE.INTERCHANGE_HEADER.INTERCHANGE_RECEIVER_ID;
foreach (PRODUCT_TRANSFER_AND_RESALE_REPORTINTERCHANGEFUNCTIONAL_GROUP funcGroup in obj.INTERCHANGE.FUNCTIONAL_GROUP)
{
if (command.Parameters.Contains("@OriginalFilename")) command.Parameters.Remove("@OriginalFilename");
command.Parameters.Add(new SqlParameter("@OriginalFilename", SqlDbType.NVarChar,500)) ;
command.Parameters["@OriginalFilename"].Value = filename;
command.Parameters.Add(new SqlParameter("@Distributor", SqlDbType.NVarChar,500)) ;
command.Parameters["@Distributor"].Value = "-";
foreach (PRODUCT_TRANSFER_AND_RESALE_REPORTINTERCHANGEFUNCTIONAL_GROUPTRANSACTIONNAME_INFO ni in funcGroup.TRANSACTION.NAME_INFO){
if (command.Parameters.Contains("@DE_DistributionCenterNR")) command.Parameters.Remove("@DE_DistributionCenterNR");
if (command.Parameters.Contains("@DE_DistributionCenterID")) command.Parameters.Remove("@DE_DistributionCenterID");
if (command.Parameters.Contains("@DE_DistributionCenterName")) command.Parameters.Remove("@DE_DistributionCenterName");
if (ni.IDENTIFICATION_CODE_QUALIFIER.Equals("ZZ"))
{
if (command.Parameters.Contains("@Distributor")) command.Parameters.Remove("@Distributor");
command.Parameters.Add(new SqlParameter("@Distributor", SqlDbType.NVarChar,500)) ;
command.Parameters["@Distributor"].Value = ni.IDENTIFICATION_CODE;
}
command.Parameters.Add(new SqlParameter("@DE_DistributionCenterNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_DistributionCenterNR"].Value = ni.IDENTIFICATION_CODE;
command.Parameters.Add(new SqlParameter("@DE_DistributionCenterID", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_DistributionCenterID"].Value = ni.IDENTIFICATION_CODE;//identifier code intern
command.Parameters.Add(new SqlParameter("@DE_DistributionCenterName", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_DistributionCenterName"].Value = ni.NAME;//iodentifeirname
}
foreach (DTM dtm in funcGroup.TRANSACTION.DTM){
if (dtm.DATE_QUALIFIER.Equals("090")) {
if (command.Parameters.Contains("@DE_Date")) command.Parameters.Remove("@DE_Date");
command.Parameters.Add(new SqlParameter("@DE_Date", SqlDbType.DateTime )) ;
command.Parameters["@DE_Date"].Value=dtm.DATE; //090 start, 091 end
}
}
if (command.Parameters.Contains("@DE_VendorDEANR")) command.Parameters.Remove("@DE_VendorDEANR");
if (command.Parameters.Contains("@DE_VendorName")) command.Parameters.Remove("@DE_VendorName");
command.Parameters.Add(new SqlParameter("@DE_VendorDEANR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_VendorDEANR"].Value = "-";
command.Parameters.Add(new SqlParameter("@DE_VendorName", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_VendorName"].Value = "-";
foreach (PRODUCT_TRANSFER_AND_RESALE_REPORTINTERCHANGEFUNCTIONAL_GROUPTRANSACTIONPTD ptd in funcGroup.TRANSACTION.PTD){
if (command.Parameters.Contains("@DE_ItemNR")) command.Parameters.Remove("@DE_ItemNR");
if (command.Parameters.Contains("@DE_ItemNDCNR")) command.Parameters.Remove("@DE_ItemNDCNR");
if (command.Parameters.Contains("@DE_ProductUOM")) command.Parameters.Remove("@DE_ProductUOM");
if (command.Parameters.Contains("@DE_CustomerAccountNR")) command.Parameters.Remove("@DE_CustomerAccountNR");
if (command.Parameters.Contains("@DE_CustomerDEANR")) command.Parameters.Remove("@DE_CustomerDEANR");
if (command.Parameters.Contains("@DE_CustomerNPINR")) command.Parameters.Remove("@DE_CustomerNPINR");
if (command.Parameters.Contains("@DE_CustomerHINNR")) command.Parameters.Remove("@DE_CustomerHINNR");
if (command.Parameters.Contains("@DE_CustomerName")) command.Parameters.Remove("@DE_CustomerName");
if (command.Parameters.Contains("@DE_CustomerCity")) command.Parameters.Remove("@DE_CustomerCity");
if (command.Parameters.Contains("@DE_CustomerState")) command.Parameters.Remove("@DE_CustomerState");
if (command.Parameters.Contains("@DE_CustomerZipcode")) command.Parameters.Remove("@DE_CustomerZipcode");
if (command.Parameters.Contains("@DE_CustomerCountry")) command.Parameters.Remove("@DE_CustomerCountry");
if (command.Parameters.Contains("@DE_QuantitySold")) command.Parameters.Remove("@DE_QuantitySold");
if (command.Parameters.Contains("@DE_QuantityReturned")) command.Parameters.Remove("@DE_QuantityReturned");
if (command.Parameters.Contains("@DE_SalesReturnCode")) command.Parameters.Remove("@DE_SalesReturnCode");
if (command.Parameters.Contains("@DE_ContractNR")) command.Parameters.Remove("@DE_ContractNR");
if (command.Parameters.Contains("@DE_Price")) command.Parameters.Remove("@DE_Price");
command.Parameters.Add(new SqlParameter("@DE_ItemNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_ItemNR"].Value = ptd.NAME_INFO.SALES_ITEM_INFORMATION.PRODUCT_SERVICE_ID;
command.Parameters.Add(new SqlParameter("@DE_ItemNDCNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_ItemNDCNR"].Value = ptd.NAME_INFO.SALES_ITEM_INFORMATION.PRODUCT_SERVICE_ID;
command.Parameters.Add(new SqlParameter("@DE_ProductUOM", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_ProductUOM"].Value = ptd.NAME_INFO.SALES_ITEM_INFORMATION.UNIT_OR_BASIS_FOR_MEASUREMENT_CODE;
command.Parameters.Add(new SqlParameter("@DE_CustomerAccountNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerAccountNR"].Value = ptd.NAME_INFO.IDENTIFICATION_CODE;
if (ptd.NAME_INFO.IDENTIFICATION_CODE_QUALIFIER.Equals("11")){
command.Parameters.Add(new SqlParameter("@DE_CustomerDEANR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerDEANR"].Value = ptd.NAME_INFO.IDENTIFICATION_CODE;
command.Parameters.Add(new SqlParameter("@DE_CustomerNPINR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerNPINR"].Value = "-";
command.Parameters.Add(new SqlParameter("@DE_CustomerHINNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerHINNR"].Value = "-";
}else if (ptd.NAME_INFO.IDENTIFICATION_CODE_QUALIFIER.Equals("21")){
command.Parameters.Add(new SqlParameter("@DE_CustomerDEANR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerDEANR"].Value = "-";
command.Parameters.Add(new SqlParameter("@DE_CustomerNPINR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerNPINR"].Value = "-";
command.Parameters.Add(new SqlParameter("@DE_CustomerHINNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerHINNR"].Value = ptd.NAME_INFO.IDENTIFICATION_CODE;
}
command.Parameters.AddWithValue("@DE_CustomerName", SqlDbType.NVarChar ).Value=ptd.NAME_INFO.NAME;
foreach (PRODUCT_TRANSFER_AND_RESALE_REPORTINTERCHANGEFUNCTIONAL_GROUPTRANSACTIONPTDNAME_INFOADDRESS_INFO add in ptd.NAME_INFO.ADDRESS_INFO){
if (command.Parameters.Contains("@DE_CustomerAddress1")) command.Parameters.Remove("@DE_CustomerAddress1");
if (command.Parameters.Contains("@DE_CustomerAddress2")) command.Parameters.Remove("@DE_CustomerAddress2");
command.Parameters.Add(new SqlParameter("@DE_CustomerAddress1", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerAddress1"].Value = add.ADDRESS_INFORMATION_1;
command.Parameters.Add(new SqlParameter("@DE_CustomerAddress2", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerAddress2"].Value = add.ADDRESS_INFORMATION_2;
}
command.Parameters.Add(new SqlParameter("@DE_CustomerCity", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerCity"].Value = ptd.NAME_INFO.GEOGRAPHIC_LOCATION.CITY_NAME;
command.Parameters.Add(new SqlParameter("@DE_CustomerState", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerState"].Value = ptd.NAME_INFO.GEOGRAPHIC_LOCATION.STATE_OR_PROVINCE_CODE;
command.Parameters.Add(new SqlParameter("@DE_CustomerZipcode", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerZipcode"].Value = ptd.NAME_INFO.GEOGRAPHIC_LOCATION.POSTAL_CODE;
command.Parameters.Add(new SqlParameter("@DE_CustomerCountry", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_CustomerCountry"].Value = ptd.NAME_INFO.GEOGRAPHIC_LOCATION.COUNTRY_CODE;
foreach (PRODUCT_TRANSFER_AND_RESALE_REPORTINTERCHANGEFUNCTIONAL_GROUPTRANSACTIONPTDNAME_INFOSALES_ITEM_INFORMATIONREF_ID refid in ptd.NAME_INFO.SALES_ITEM_INFORMATION.REF_ID ){
if (refid.REFERENCE_IDENTIFICATION_QUALIFIER.Contains("DI")){
if (command.Parameters.Contains("@DE_InvoiceNR")) command.Parameters.Remove("@DE_InvoiceNR");
if (command.Parameters.Contains("@DE_Invoicedate")) command.Parameters.Remove("@DE_Invoicedate");
command.Parameters.Add(new SqlParameter("@DE_InvoiceNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_InvoiceNR"].Value = refid.REFERENCE_IDENTIFICATION;
command.Parameters.Add(new SqlParameter("@DE_Invoicedate", SqlDbType.DateTime)) ;
command.Parameters["@DE_Invoicedate"].Value = refid.DATE;
}
}
command.Parameters.Add(new SqlParameter("@DE_QuantitySold", SqlDbType.Decimal, 18)) ;
command.Parameters["@DE_QuantitySold"].Value = ptd.NAME_INFO.SALES_ITEM_INFORMATION.QUANTITY;
command.Parameters.Add(new SqlParameter("@DE_QuantityReturned", SqlDbType.Decimal,18)) ;
command.Parameters["@DE_QuantityReturned"].Value = ptd.NAME_INFO.SALES_ITEM_INFORMATION.QUANTITY;
command.Parameters.Add(new SqlParameter("@DE_SalesReturnCode", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_SalesReturnCode"].Value = "-";
command.Parameters.Add(new SqlParameter("@DE_ContractNR", SqlDbType.NVarChar,500)) ;
command.Parameters["@DE_ContractNR"].Value = ptd.NAME_INFO.SALES_ITEM_INFORMATION.PRODUCT_SERVICE_ID;
command.Parameters.Add(new SqlParameter("@DE_Price", SqlDbType.Decimal,18)) ;
command.Parameters["@DE_Price"].Value = ptd.NAME_INFO.SALES_ITEM_INFORMATION.MONETARY_AMOUNT;
for (int i = 0; i < command.Parameters.Count; i++)
{
if (command.Parameters[i].SqlDbType == SqlDbType.NVarChar) command.Parameters[i].Size = 500;
if (command.Parameters[i].SqlDbType == SqlDbType.Decimal)
{
command.Parameters[i].Size = 18;
command.Parameters[i].Scale = 6;
}
if (!SALESDATAQRY.Contains(command.Parameters[i].ParameterName)) logger.Error("Parameter not found: " + command.Parameters[i].ParameterName);
logger.Info(command.Parameters[i].ParameterName + ": " + command.Parameters[i].SqlDbType + " " + command.Parameters[i].Size + " " + command.Parameters[i].Scale + " " + command.Parameters[i].Value);
}
command.Prepare();
logger.Info("inserted " + command.ExecuteNonQuery()+ " rows");
}
}
答案 0 :(得分:0)
或者,您可以使用隐式为您投射数据类型的AddWithValue
,
command.Parameters.AddWithValue("@InterchangeReceiverID", "VALUEGOESHERE");
答案 1 :(得分:0)
您可以使用以下语法:
var parameter = new SqlParameter("@InterchangeReceiverID", SqlDbType.NVarChar, 500);
parameter.Value = "VALUEGOESHERE";
command.Parameters.Add(parameter);
答案 2 :(得分:0)
尝试使用command.CreateParameter()
而不是SqlParameter
。