如何使用数组值更新数据库中的列?

Posted

技术标签:

【中文标题】如何使用数组值更新数据库中的列?【英文标题】:How to update a column in a database with array values? 【发布时间】:2011-12-17 17:02:51 【问题描述】:

我有一个int 数组,里面有一些值,它的大小是未知的(动态填充)。我想用这个数组更新数据库中的一列(即数据库中第 n 条记录的列 m 将用数组的第 n 个元素更新)。我怎样才能做到这一点?我是否应该在单独的 sql 中更新表的每条记录,如下所示:

for(int i = 0; i < array.Length; i++)

    string sqlCommand = "UPDATE TABLENAME SET THECOLUMN = " + array[i] + " WHERE ID = " + (i+1);
    // Execute the command

,或者有更有效或更简单的方法吗?

PS:我正在使用 ACCESS 数据库,通过 C# 将其连接到(ASP.NET)网站

【问题讨论】:

【参考方案1】:

我会在一次往返中完成

StringBuilder command = new StringBuilder();
for(int i = 0; i < array.Length; i++) 
    command.Append("UPDATE TABLENAME SET THECOLUMN = " + array[i] + 
                " WHERE ID = " + (i+1) + ";");

// Execute the command HERE

与数据库的“来回”相当昂贵,因此您通常希望您的通信“笨拙而不啰嗦”。

【讨论】:

以上是关于如何使用数组值更新数据库中的列?的主要内容,如果未能解决你的问题,请参考以下文章

如何通过读取、递增和更新数据库中的列来有效地保持计数

如何使用计数查询来(自动)更新表中的列

如何使用计算值更新带有 PL\SQL 的列

如何使用不相关表中的列数据更新列 - MySQL

根据另一列值更新数据框的列

当没有明确的列可以加入时,如何使用另一个表中的值更新 sql 表?