01-06-01【Nhibernate (版本3.3.1.4000) 出入江湖】事务
2014-05-27 20:32
363 查看
Nhibernate事务的使用:
测试:
-----------------------------------------------
关于事务操作的添加:
session.Flush();//清除一级缓存
是否会立即保存到数据库
结论是:不会立即保存的数据库,而是等到调用transaction.Commit();才真正保存到数据库:
图解:
public void Add(Customer customer) { ISession session = _sessionManager.GetSession(); ITransaction transaction = session.BeginTransaction(); try { session.Save(customer); session.Flush();//清除一级缓存 transaction.Commit(); } catch (Exception) { transaction.Rollback(); } finally { session.Close(); } }
测试:
[TestMethod] [ExpectedException(typeof(NHibernate.Exceptions.GenericADOException))] public void TestAddTransation() { CustomerService customerService = new CustomerService(); OrderService orderService = new OrderService(); Customer customer1 = new Customer() { FirstName = "Test", LastName = "TestAddTransation1", Age = 10 }; Order order1 = new Order() { OrderDate = DateTime.Now.AddMinutes(1), Customer = customer1 }; Order order2 = new Order() { OrderDate = DateTime.Now.AddMinutes(2), Customer = customer1 }; Customer customer2= new Customer() { FirstName = null, //数据库要求不能为null,现在故意引发添加异常 LastName = "TestAddTransation", Age = 10 }; Order order3 = new Order() { OrderDate = DateTime.Now.AddMinutes(3), Customer = customer2 }; Order order4 = new Order() { OrderDate = DateTime.Now.AddMinutes(4), Customer = customer2 }; customer1.Orders.Add(order1); customer1.Orders.Add(order2); customer2.Orders.Add(order3); customer2.Orders.Add(order4); customerService.Add(customer1); //customer1及其Order1与Order2能成功插入,因为他们与Customer2不在同一个事务 customerService.Add(customer2); //Customer2插入失败,Order3和Order4也不能成功插入。 Assert.IsNull(customerService.Get(customer1.CustomerId)); Assert.IsNull(orderService.Find(order1.OrderId)); Assert.IsNull(orderService.Find(order2.OrderId)); }
-----------------------------------------------
关于事务操作的添加:
session.Flush();//清除一级缓存
是否会立即保存到数据库
结论是:不会立即保存的数据库,而是等到调用transaction.Commit();才真正保存到数据库:
图解:
相关文章推荐
- 01-03-02-2【Nhibernate (版本3.3.1.4000) 出入江湖】CRUP操作-Save方法的一些问题
- 01-05-01-1【Nhibernate (版本3.3.1.4000) 出入江湖】延迟加载及其class和集合(set、bag等)的Lazy属性配置组合对Get和Load方法的影响
- 01-04-01【Nhibernate (版本3.3.1.4000) 出入江湖】原生的SQL查询
- 01-05-01-2【Nhibernate (版本3.3.1.4000) 出入江湖】立即加载实现--NHibernateUtil.Initialize()和添加fetch关键字的HQL查询
- 01-08-02【Nhibernate (版本3.3.1.4000) 出入江湖】二级缓存:NHibernate自带的HashtableProvider
- 01-08-01【Nhibernate (版本3.3.1.4000) 出入江湖】NHibernate中的三种状态
- 01-08-03【Nhibernate (版本3.3.1.4000) 出入江湖】二级缓存:NHibernate自带的HashtableProvider之查询缓存
- 01-08-05【Nhibernate (版本3.3.1.4000) 出入江湖】NHibernate二级缓存:第三方MemCache缓存
- 01-04-02【Nhibernate (版本3.3.1.4000) 出入江湖】HQL查询
- 01-01-01【Nhibernate (版本3.3.1.4000) 出入江湖】配置文件
- 01-08-01【Nhibernate (版本3.3.1.4000) 出入江湖】NHibernate中的一级缓存
- 01-08-04【Nhibernate (版本3.3.1.4000) 出入江湖】二级缓存:NHibernate自带的HashtableProvider之命名缓存
- 01-03-02-1【Nhibernate (版本3.3.1.4000) 出入江湖】CRUP操作--cascade 级联相关
- 01-07-01【Nhibernate (版本3.3.1.4000) 出入江湖】并发控制
- 01-08-03【Nhibernate (版本3.3.1.4000) 出入江湖】二级缓存:NHibernate自带的HashtableProvider之缓存管理
- 01-03-01【Nhibernate (版本3.3.1.4000) 出入江湖】id标签的unsaved-value属性
- 01-04-03【Nhibernate (版本3.3.1.4000) 出入江湖】Criteria API关联查询
- 01-03-03【Nhibernate (版本3.3.1.4000) 出入江湖】cascade的测试
- SQL优化(六) MVCC PostgreSQL实现事务和多版本并发控制的精华
- Leetcode: 06/01