数据库连接忘记关闭解决方案

做项目的时候又是经常忘记关闭数据库的连接,造成了资源拥堵,总结一下怎么解决的:

以下几个解决方案:

 

解决方法:
1   修改几个关键页面或访问比较频繁的数据库访问操作,使用DataAdapter和DataSet来获取数据库数据,不要使用DataReader。
2   在访问数据库的页面上使用数据缓存,如果页面的数据不是经常更新(几分钟更新一次)的话,使用Cache对象可以不用访问数据库而使用缓存中的内容,那么可以大大减少连接数量。
3   修改代码,把使用Connection对象的地方都在Close()后面加上Dispose()调用。
4  建议对数据库操作进行大的修改,建立自己的数据库操作代理类,继承System.IDisposable接口,强迫释放资源,这样就不会出现连接数量不够的问题了。
5SqlCommand myCommand = new SqlCommand(myInsertQuery);
myCommand.Connection.Close();
myCommand.Dispose();

解决方案二

解决方法(*):WEB.config 里面:在数据库连接加 Max Pool Size = 512;server=local;uid=;pwd=;database=***;Max Pool Size = 512;">一劳永逸。

解决方案三

估计是连接(Connection)对象没有Close。倒是不必Dispose,而DataReader用完后应该关闭,但不关闭也没问题,只是不关闭的话此连接对象就一直不能用,只要你最终关闭了连接对象就不会出问题。

连接对象在Open后的操作都放在try块中,后面跟一个finally块:conn.Close();

转载于:https://www.cnblogs.com/skyfreedom/p/4669822.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的VB连接SQL数据库的示例: 首先,您需要在VB项目中添加ADO.NET引用。在解决方案资源管理器中右键单击项目,选择“添加引用”,然后选中“System.Data”和“System.Data.SqlClient”。 接下来,您需要创建一个SqlConnection对象,并提供连接字符串来连接到SQL数据库。连接字符串中包含了数据库的名称、服务器名称、验证方式等信息。 ```vb Dim connectionString As String = "Data Source=服务器名称;Initial Catalog=数据库名称;Integrated Security=True" Dim connection As New SqlConnection(connectionString) ``` 然后,您可以打开数据库连接,并执行任何需要的操作,例如执行SQL查询、插入、更新或删除数据。 ```vb Try ' 打开数据库连接 connection.Open() ' 执行SQL查询 Dim query As String = "SELECT * FROM 表名" Dim command As New SqlCommand(query, connection) Dim reader As SqlDataReader = command.ExecuteReader() ' 遍历查询结果 While reader.Read() Dim column1 As String = reader("列名1").ToString() Dim column2 As String = reader("列名2").ToString() ' 处理查询结果 End While ' 关闭数据阅读器 reader.Close() ' 插入数据 Dim insertQuery As String = "INSERT INTO 表名 (列名1, 列名2) VALUES ('值1', '值2')" Dim insertCommand As New SqlCommand(insertQuery, connection) insertCommand.ExecuteNonQuery() ' 更新数据 Dim updateQuery As String = "UPDATE 表名 SET 列名1 = '新值' WHERE 列名2 = '某条件'" Dim updateCommand As New SqlCommand(updateQuery, connection) updateCommand.ExecuteNonQuery() ' 删除数据 Dim deleteQuery As String = "DELETE FROM 表名 WHERE 列名 = '某条件'" Dim deleteCommand As New SqlCommand(deleteQuery, connection) deleteCommand.ExecuteNonQuery() ' 关闭数据库连接 connection.Close() Catch ex As Exception ' 处理异常 Finally ' 确保关闭数据库连接 If connection.State = ConnectionState.Open Then connection.Close() End If End Try ``` 最后,不要忘记在处理完数据库操作后关闭数据库连接,以释放资源。 这是一个简单的VB连接SQL数据库的实例,您可以根据具体需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值