您的位置:首页 > 数据库

关于数据库操作及事务的处理

2014-08-27 20:18 253 查看
DAL基于ADO.NET的话,那么可以为你的DAL增加一个返回 DbTransaction 对象的方法,然后使用类似这样的工厂方法

C# code

?
总之你的所谓DAL方法要作出修改,它如果需要访问数据库,那么从传入的tran中去取得 Connection 属性,并调用 Connection 的 CreateCommand 方法来创建 Command,来操作数据库。

事务只在同一线程的同一数据库连接下有效,

而另一方面,每一个具体的业务,会包括大量的实体类的增删改查处理,

如果由DAL控制事务,每一次都要频繁的开关数据库,有可能会很浪费资源。

事务的目的是回滚,采用DAL控制的方式无法进行回滚。

因此,事务的发起与结束只能有业务层控制,而不能由DAL控制,这就决定了数据库的开关也只能由BLL说了算。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐