文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

避免在循环中调用数据库操作:提升C#程序性能的有效方法

2024-11-29 20:24

关注

为什么要避免在循环中调用数据库操作?

在循环中进行数据库操作会带来以下几个问题:

方法一:批量操作

示例1:批量插入数据

不建议的方法:

foreach (var item in list)
{
    using (var connection = new SqlConnection(connectionString))
    {
        var command = new SqlCommand("INSERT INTO MyTable (Col1) VALUES (@value)", connection);
        command.Parameters.AddWithValue("@value", item);
        connection.Open();
        command.ExecuteNonQuery();
    }
}

建议的方法:

using (var connection = new SqlConnection(connectionString))
{
    connection.Open();
    using (var transaction = connection.BeginTransaction())
    {
        var command = new SqlCommand();
        command.Connection = connection;
        command.Transaction = transaction;
        foreach (var item in list)
        {
            command.CommandText += "INSERT INTO MyTable (Col1) VALUES (@value_" + item.Id + ");";
            command.Parameters.AddWithValue("@value_" + item.Id, item.Value);
        }
        command.ExecuteNonQuery();
        transaction.Commit();
    }
}

通过批量操作,可以减少数据库交互次数,极大地提升性能。

方法二:缓存数据到内存中

示例2:缓存数据一次性加载

不建议的方法:

foreach (var item in list)
{
    using (var connection = new SqlConnection(connectionString))
    {
        var command = new SqlCommand("SELECT * FROM MyTable WHERE Id = @id", connection);
        command.Parameters.AddWithValue("@id", item.Id);
        connection.Open();
        var reader = command.ExecuteReader();
        while (reader.Read())
        {
            // 处理数据
        }
    }
}

建议的方法:

var data = new List();
using (var connection = new SqlConnection(connectionString))
{
    var command = new SqlCommand("SELECT * FROM MyTable WHERE SomeCondition = @condition", connection);
    command.Parameters.AddWithValue("@condition", condition);
    connection.Open();
    var reader = command.ExecuteReader();
    while (reader.Read())
    {
        var dataItem = new DataItem
        {
            Id = reader.GetInt32(0),
            Name = reader.GetString(1)
        };
        data.Add(dataItem);
    }
}
// 在内存中处理数据
foreach (var item in data)
{
    item.Processed = true;
}


using (var connection = new SqlConnection(connectionString))
{
    connection.Open();
    foreach (var item in data)
    {
        var command = new SqlCommand("UPDATE MyTable SET Processed = @processed WHERE Id = @id", connection);
        command.Parameters.AddWithValue("@processed", item.Processed);
        command.Parameters.AddWithValue("@id", item.Id);
        command.ExecuteNonQuery();
    }
}

示例3:预加载数据

将数据加载到内存中进行处理而不是在循环中每次访问数据库,可以显著提高性能。

方法三:使用存储过程

示例4:使用存储过程进行批量更新

SQL Server 中存储过程示例:

CREATE PROCEDURE BulkUpdateMyTable
   @DataTable MyTableType READONLY
AS
BEGIN
    UPDATE t
    SET t.Processed = d.Processed
    FROM MyTable t
    INNER JOIN @DataTable d ON t.Id = d.Id
END

C#代码调用存储过程:

DataTable dataTable = new DataTable();
dataTable.Columns.Add("Id", typeof(int));
dataTable.Columns.Add("Processed", typeof(bool));


foreach (var item in data)
{
    dataTable.Rows.Add(item.Id, item.Processed);
}


using (var connection = new SqlConnection(connectionString))
{
    connection.Open();
    using (var command = new SqlCommand("BulkUpdateMyTable", connection))
    {
        command.CommandType = CommandType.StoredProcedure;
        var parameter = command.Parameters.AddWithValue("@DataTable", dataTable);
        parameter.SqlDbType = SqlDbType.Structured;
        command.ExecuteNonQuery();
    }
}

通过使用存储过程,可以一次性将所有需要处理的数据传递给存储过程,由存储过程完成批量处理。

结论

在C#程序开发中,通过避免在循环中调用数据库操作,可以显著提升程序性能,减少数据库负担,提升代码的可维护性。本文通过三个主要的方法(批量操作、缓存数据和使用存储过程)提供了详细的解决方案和示例代码,希望能够帮助开发者更好地优化数据库交互操作。

在实际开发中,应根据具体的业务场景选择合适的方法进行优化,从而提升系统的整体性能和稳定性。

来源:技术老小子内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯