我看到其他一些人遇到了类似的问题。我已阅读并检查了标题为Procedure expects parameter which was not supplied的问题。我认为它可以解决我的问题,但我错了:(我确实检查了那些没有运气的建议步骤。这是我的代码:
oOleDbCommand.CommandText = "usp_PettyCash_AddBillInfo";
oOleDbCommand.Parameters.Add("@BillID", OleDbType.BigInt).Value = nBillID;
oOleDbCommand.Parameters.Add("@SerialNo", OleDbType.VarChar).Value = sSerialNo;
oOleDbCommand.Parameters.Add("@UniqueID", OleDbType.VarChar).Value = oInputBill[0].UniqueID.ToString();
oOleDbCommand.Parameters.Add("@BilledWeekDate", OleDbType.Date).Value = oInputBill[0].BilledWeekDate;
oOleDbCommand.Parameters.Add("@BilledWeekNo", OleDbType.VarChar).Value = oInputBill[0].BilledWeekNo.ToString();
oOleDbCommand.Parameters.Add("@SettledWeekDate", OleDbType.Date).Value = oInputBill[0].SettledWeekDate;
oOleDbCommand.Parameters.Add("@SettledWeekNo", OleDbType.VarChar).Value = oInputBill[0].SettledWeekNo;
oOleDbCommand.Parameters.Add("@BillStatus", OleDbType.VarChar).Value = oInputBill[0].BillStatus.ToString();
oOleDbCommand.Parameters.Add("@UpdatedBy", OleDbType.VarChar).Value = oInputBill[0].UpdatedBy;
oOleDbCommand.Parameters.Add("@UpdateDate", OleDbType.Date).Value = oInputBill[0].UpdateDate;
存储过程是:
CREATE PROCEDURE usp_PettyCash_AddBillInfo
(
@BillID bigint,
@SerialNo varchar(50),
@UniqueID varchar(50),
@BilledWeekDate datetime,
@BilledWeekNo varchar(50),
@SettledWeekDate datetime,
@SettledWeekNo varchar(50),
@BillStatus varchar(50),
@UpdatedBy varchar(50),
@UpdateDate datetime
)
AS
BEGIN
INSERT INTO t_BillInfo (BillID, SerialNo, UniqueID, BilledWeekDate, BilledWeekNo, SettledWeekDate, SettledWeekNo, BillStatus, UpdatedBy, UpdateDate)
VALUES (@BillID, @SerialNo, @UniqueID, @BilledWeekDate, @BilledWeekNo, @SettledWeekDate, @SettledWeekNo, @BillStatus, @UpdatedBy, @UpdateDate)
END
GO
调试时,我找到了nBillID = 1.0
和sSerialNo='B201200001'
的值。但是在尝试执行ExecuteNonQuery
命令时,它会给出异常:
“程序'usp_PettyCash_AddBillInfo'需要参数'@BillID', 这是没有提供的。“
我找不到任何解决方法。请帮忙。很抱歉重新提问。
作为解决方法,我使用了这个:
oOleDbCommand.CommandText = "INSERT INTO t_BillInfo (BillID, SerialNo, UniqueID, BilledWeekDate, BilledWeekNo, SettledWeekDate, SettledWeekNo, BillStatus, UpdatedBy, UpdateDate)"+
" VALUES (" + nBillID + ", '" + sSerialNo + "', '" + oInputBill[0].UniqueID.ToString() + "','" + oInputBill[0].BilledWeekDate.ToShortDateString() + "', '" + oInputBill[0].BilledWeekNo + "', '" + oInputBill[0].SettledWeekDate.ToShortDateString() + "', '" + oInputBill[0].SettledWeekNo + "', '" + oInputBill[0].BillStatus.ToString() + "', '" + oInputBill[0].UpdatedBy + "', '" + oInputBill[0].UpdateDate.ToShortDateString() + "')";
虽然我不喜欢这种类型的编码,但这很有效。
答案 0 :(得分:3)
尝试添加:
oOleDbCommand.CommandType = CommandType.StoredProcedure;
我相信没有这个,你的参数值应该是内联添加的(就像一个内联SQL语句)。 E.g:
oOleDbCommand.CommandText = "usp_PettyCash_AddBillInfo @BillID, @SerialNo...";
因此,您将参数添加到命令中,但它们不在CommandText中,因此它们不会在任何地方应用。
要调用存储过程,请设置Command对象的 CommandType 到 StoredProcedure 。将CommandType设置为StoredProcedure后, 您可以使用Parameters集合来定义参数,如 以下示例。
http://msdn.microsoft.com/en-us/library/yy6y35y8(v=vs.71).aspx