【问题标题】:how can i update SQL table logic我如何更新 SQL 表逻辑
【发布时间】:2013-05-08 12:08:34
【问题描述】:

我有一个结构如下的表格,

Table 3

Fruit ID -  Foreign Key  (Primary Key of Table 1)
Crate ID -  Foreign Key  (Primary Key of Table 2)

现在我需要执行一个查询,

更新 Crate ID of Fruit ID if Fruit ID 已经在表中,如果没有则插入记录在表 3 中作为新记录。

这是我现在在代码中得到的,

private void RelateFuirtWithCrates(List<string> selectedFruitIDs, int selectedCrateID)
{

   string insertStatement = "INSERT INTO Fruit_Crate(FruitID, CrateID) Values " +
        "(@FruitID, @CrateID);";  ?? I don't think if it's right query

        using (SqlConnection connection = new SqlConnection(ConnectionString()))
        using (SqlCommand cmd = new SqlCommand(insertStatement, connection))
        {
            connection.Open();
            cmd.Parameters.Add(new SqlParameter("@FruitID", ????? Not sure what goes in here));
            cmd.Parameters.Add(new SqlParameter("@CrateID",selectedCrateID));        
}

【问题讨论】:

标签: c# sql sql-server webforms


【解决方案1】:

您可以在 SQL Server 中使用 MERGE 语法进行“更新插入”:

MERGE [SomeTable] AS target
USING (SELECT @FruitID, @CrateID) AS source (FruitID, CrateID)
ON (target.FruitID = source.FruitID)
WHEN MATCHED THEN 
    UPDATE SET CrateID = source.CrateID
WHEN NOT MATCHED THEN   
    INSERT (FruitID, CrateID)
    VALUES (source.FruitID, source.CrateID);

否则,你可以使用类似的东西:

update [SomeTable] set CrateID = @CrateID where FruitID = @FruitID
if @@rowcount = 0
    insert [SomeTable] (FruitID, CrateID) values (@FruitID, @CrateID)

【讨论】:

  • @user13814 MERGE 语法适用于列表,但是:就参数而言,这并不容易。您需要查看“表值参数”或使用某种“拆分”udf。或者只是添加很多参数。
  • 谢谢,但是我仍然对如何将 FruitIDs 添加为 sql 参数先生感到困惑,所以问了另一个问题,stackoverflow.com/questions/16539948/…
  • @user13814 这实际上是一件非常困难的事情;我在您后来的一个问题中添加了一个使用“dapper”的示例 - 我们专门添加了一些帮助代码来支持这种常见但令人烦恼的场景
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-01-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多