如何从 asmx Web 服务管理多个 ado.net 数据库连接

Posted

技术标签:

【中文标题】如何从 asmx Web 服务管理多个 ado.net 数据库连接【英文标题】:how to manage multiple ado.net database connections from asmx Web Service 【发布时间】:2010-12-20 07:28:07 【问题描述】:

由于 IIS 为每个请求分配一个工作线程,我打算创建新对象来服务每个请求。我有两个问题:

    为每个请求创建新对象是否有效? (还有替代品吗?)

    创建新连接并为每个请求打开和关闭它是否是线程安全、高效和最佳实践,如下所示:

使用 (mysqlConnection conn = new MySqlConnection(ConfigurationManager.ConnectionStrings["MySqlConnectionString"].ConnectionString)) conn.Open(); MySqlCommand cmd = new MySqlCommand("SELECT password FROM Admin WHERE username='" + username + "'", conn); 对象 dbp = cmd.ExecuteScalar(); conn.Close();

PS。这个例子取自这个网站。我使用 oracle 数据库。

谢谢:马蒂

【问题讨论】:

【参考方案1】:

当您执行new SomeSqlConnection() 时,您实际上不会每次都创建新连接。由于创建数据库连接的成本很高,ADO.NET 保留一个连接池并从那里提取连接。您还可以删除对 Close 方法的调用。这是一个可以在每个请求中安全使用的 sn-p:

var connectionString = ConfigurationManager.ConnectionStrings["MySqlConnectionString"].ConnectionString;
using (var conn = new MySqlConnection(connectionString))
using (var cmd = conn.CreateCommand())
 
    conn.Open();
    cmd.CommandText = "SELECT count(*) from some_table";
    object result = cmd.ExecuteScalar();

【讨论】:

感谢您的快速答复。听起来很好。但这是最佳做法吗?使用下面的东西怎么样?私有静态 DbProviderFactory 工厂 = DbProviderFactories.GetFactory("System.Data.SqlClient"); @darin 谢谢,这有助于减少响应时间【参考方案2】:

正如 Darin 在 his answer 中正确指出的那样,您应该允许连接池机制完成其工作。不要尝试构建“聪明”的东西,它不会那么好。

数据库连接等资源昂贵的黄金法则是迟获取早释放。只要你遵守它,你就会做得很好。

【讨论】:

以上是关于如何从 asmx Web 服务管理多个 ado.net 数据库连接的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 iOS SDK 从 ASMX Web 服务中获取和解析 JSON?

如何使用 Retrofit 在 android 中调用图像上传 Web 服务 (ASP.NET) .asmx 文件

如何删除 asmx 端点?

从 Web 服务 (ASMX) 调用第三方 API

从 Javascript 调用 ASMX Web 服务

从 Web 服务 (asmx) 页面引用 asp.net 页面上的字段