首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySqlConnection线程优化

MySqlConnection线程优化
EN

Stack Overflow用户
提问于 2021-01-31 06:54:21
回答 1查看 30关注 0票数 0

如何优化连接到数据库的函数,以便在多个用户同时访问数据库时,服务器不会崩溃或产生另一个问题。可以使用线程化吗?有没有可能,如果数据库延迟响应,主线程会冻结或阻塞其他代码?

代码语言:javascript
复制
public static void UpdatePassword(string email, string password)
    {
        using (MySqlConnection connection = new MySqlConnection(""))
        {
            connection.Open();
            MySqlCommand command = connection.CreateCommand();

            string saltedPassword = PasswordDerivation.Derive(password);

            command.CommandText = "UPDATE users SET password=@password WHERE email=@email LIMIT 1";
            command.Parameters.AddWithValue("@email", email);
            command.Parameters.AddWithValue("@password", saltedPassword);

            command.ExecuteNonQuery();
            connection.Close();
        }
    }
EN

回答 1

Stack Overflow用户

发布于 2021-02-07 10:09:23

在大多数情况下,单个“程序”应该使用到数据库的单个连接。拥有大量的“连接”会产生开销,至少在创建连接时是这样。

异步操作在数据库工作中很少有好处,因为SQL非常擅长在单个查询中高效地处理数百万行。

MySQL非常擅长让不同的客户端同时与数据库对话。然而,这需要“事务”来防止数据被弄乱。

如果您在C#中的目标是获得一些并行性,请进一步描述它。我们要么让你相信它不会像你想象的那样有益,要么帮你重写SQL以提高效率并避免并行的需要。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65973947

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档