关于数据库连接,用using(sqlconnection sqc = new sqlconnection())的问题!

v1srine 2011-12-21 06:10:00
using (SqlConnection connection = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(SQLString, connection))
{
}
}


见天看了别人的源码!

不知道为什么要这样写!这样写的好处是什么呢?
...全文
171 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
v1srine 2011-12-22
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 dalmeeme 的回复:]
如果一个类,有Close方法和Dispose方法,就可以用using
如果仅有Dispose方法,一般没必要用using

所以只要对Connection用using就行了,其他没必要的。
[/Quote]
那么,关闭了sqlconnection sqlcommand也会自动dispose吗?
v1srine 2011-12-22
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 dalmeeme 的回复:]
如果一个类,有Close方法和Dispose方法,就可以用using
如果仅有Dispose方法,一般没必要用using

所以只要对Connection用using就行了,其他没必要的。
[/Quote]

谢谢!
dalmeeme 2011-12-22
  • 打赏
  • 举报
回复
不会,SqlCommand没必要手动执行Dispose方法,垃圾回收会自动处理的。
dalmeeme 2011-12-21
  • 打赏
  • 举报
回复
如果一个类,有Close方法和Dispose方法,就可以用using
如果仅有Dispose方法,一般没必要用using

所以只要对Connection用using就行了,其他没必要的。
v1srine 2011-12-21
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 dalmeeme 的回复:]
就是代码块中无论有异常,都会执行相应的Dispose()方法,释放资源。
在不需要获得异常信息时,比try catch finnally方便。
[/Quote]

using(SqlConnection SqlConn = new SqlConnection(SqlConnStr))
{
using(DataSet ds = new DataSet())
{
using(SqlCommand cmd = new SqlCommand(QueryStr, SqlConn))
{
using(SqlDataAdapter sda = new SqlDataAdapter(cmd))
{
sda.Fill(ds);
return ds.Tables[0];
}
}
}
}


那我这样写也行吗?
还是不需要写多这么多!
dalmeeme 2011-12-21
  • 打赏
  • 举报
回复
就是代码块中无论有异常,都会执行相应的Dispose()方法,释放资源。
在不需要获得异常信息时,比try catch finnally方便。

62,047

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧