【发布时间】:2021-12-11 12:29:14
【问题描述】:
我有以下 SQLite 表。
CREATE TABLE "Ingredient_Detailed" (
"DETAILED_INGREDIENT_ID" TEXT,
"INGREDIENT_CODE" INTEGER NOT NULL,
"BRAND" TEXT NOT NULL,
"INGREDIENT_SOURCE" TEXT NOT NULL,
"UNIT_PRICE" REAL NOT NULL DEFAULT 0,
"AMOUNT_IN_UNIT" REAL NOT NULL DEFAULT 0,
"MINIMUM_PRICE_PER_UNIT" REAL NOT NULL DEFAULT 0,
"QUALITY" INTEGER NOT NULL DEFAULT 1,
"UNITS_AVAILABLE" INTEGER NOT NULL DEFAULT 0,
FOREIGN KEY("INGREDIENT_CODE") REFERENCES "Ingredient"("CODE"),
PRIMARY KEY("DETAILED_INGREDIENT_ID")
)
我有一个 C# 应用程序,我尝试使用以下方法将记录插入此表:
public int SaveDetailedIngredient(DetailedIngredient pDetailedIngredient)
{
try
{
using (var conn = new SQLiteConnection(GetConnectionString()))
{
var saveDetailedIngredientCommand = new SQLiteCommand("INSERT INTO INGREDIENT_DETAILED (DETAILED_INGREDIENT_ID, " +
"INGREDIENT_CODE, BRAND, INGREDIENT_SOURCE, UNIT_PRICE, AMOUNT_IN_UNIT, " +
"MINIMUM_PRICE_PER_UNIT, QUALITY, UNITS_AVAILABLE) " +
"VALUES ($pDetailedIngredientId, $pCode, $pBrand, $pSource, $pUnitPrice, $pAmountInUnit, $pPricePerUnit, $pQuality, $pUnitsAvailable)", conn);
pDetailedIngredient.DetailedIngredientCode = pDetailedIngredient.Code + "-" + pDetailedIngredient.Brand + "-" + pDetailedIngredient.IngredientSource;
saveDetailedIngredientCommand.Parameters.AddWithValue("pDetailedIngredientId", pDetailedIngredient.DetailedIngredientCode);
saveDetailedIngredientCommand.Parameters.AddWithValue("pCode", pDetailedIngredient.Code);
saveDetailedIngredientCommand.Parameters.AddWithValue("pBrand", pDetailedIngredient.Brand.Trim().ToUpper());
saveDetailedIngredientCommand.Parameters.AddWithValue("pSource", pDetailedIngredient.IngredientSource.Trim().ToUpper());
saveDetailedIngredientCommand.Parameters.AddWithValue("pUnitPrice,", pDetailedIngredient.UnitPrice);
saveDetailedIngredientCommand.Parameters.AddWithValue("pAmountInUnit", pDetailedIngredient.AmountInUnit);
saveDetailedIngredientCommand.Parameters.AddWithValue("pPricePerUnit", pDetailedIngredient.MinimumUnitPrice);
saveDetailedIngredientCommand.Parameters.AddWithValue("pQuality", pDetailedIngredient.Quality);
saveDetailedIngredientCommand.Parameters.AddWithValue("pUnitsAvailable", pDetailedIngredient.UnitsAvailable);
conn.Open();
return saveDetailedIngredientCommand.ExecuteNonQuery();
}
}
catch (SQLiteException sqlEx)
{
Console.WriteLine(sqlEx.Message);
Console.WriteLine(sqlEx.ErrorCode);
throw sqlEx;
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
throw ex;
}
}
尽管指示了 9 个字段并提供了 9 个参数,但 SQLite 会抛出异常“未知错误:提供给命令的参数不足”。
我复制并粘贴了参数的名称以确保它们没有错字,但它仍然会引发错误。
我在方法执行期间调试了应用程序,提供的pDetailedIngredient 分配了所有必要的属性值,我可以看到命令中的每个参数都被正确分配。
我还有其他几种向其他表插入数据的方法,都遵循相同的结构,所以我怀疑这与我的方法的编写方式有关。
我在这里遗漏了什么吗?感觉这不是正确的错误。
【问题讨论】:
-
请在执行开始前在“saveDetailedIngredientCommand”中发布您所拥有的内容
-
我注意到文档中的示例也将
$放入传递给 AddWithValue 的参数名称中 -
@CaiusJard 是正确的。 “$”是参数名称的一部分。添加到集合中时分配给每个参数的名称应包含“$”。
-
@Mark Benningfield ...我同意它应该只是为了可读性而匹配,但是从文档中...Parameters ... “参数可以以:、@或$作为前缀。” ...我通常会以“@”字符为前缀,而其他两个不知道。另外,在我的小测试中,我尝试了在参数定义中使用/不使用前缀,它在“AddWithValue”中没有任何区别......同样的错误。在我的解决方案中,它也没有任何区别......它可以使用/不使用前缀。奇怪……
-
好吧,在不知道 OP 使用的是哪个特定的 C# 绑定的情况下,此时无话可说。
标签: c# sql sqlite prepared-statement