NHibernate中的Clear和Flush方法
2021-01-17 05:11
标签:mode list 条件 mamicode read customer parameter native 清除 在NHibernata中,提供了l缓存机制。Clear和Flush都是针对session缓存(一级缓存)中的数据。无论还是load()还是get(),都是先查询缓存(一级缓存),没有再查询数据库。如下代码,执行了同一个id的2次查询,但是执行了一次sql的查询。 虽然查询了2次,但是执行了一次sql,如图: 执行了2次sql语句: 调用Flush(),强制更新数据,更新了2次: flush()同步了数据库,但不会提交事务。commit()方法执行前,会先执行flush(),然后提交事务。提交事务意味着对数据库所做的更新被永久保存下来。通常,执行session,save,update,delete的时候,只是一个登记行为。只要调用Flush方法之后,NHiberrnate才会将缓存中的数据提交的数据库。(将登记行为的sql提交到数据库,但是还没有提交数据,只有提交事务之后,才会向数据库中提交数据,永久保存到数据库。) using (ITransaction rs = session.BeginTransaction()) 使用query.setCacheable(true),查询缓存,只有查询条件和原来查询完全相同时,才会在缓存中匹配成功: 6.如果主键使用“native”生成,则不放入二级缓存.不需要事务提交,就直接保存到数据库中了。 NHibernate中的Clear和Flush方法 标签:mode list 条件 mamicode read customer parameter native 清除 原文地址:https://www.cnblogs.com/king-tao/p/13369770.html 1 using (ITransaction rs = session.BeginTransaction())
2 {
3 TplCustomer model = session.Get(typeof(TplCustomer),150218) as TplCustomer;
4 Console.WriteLine(model.LastName);
5 var model_1 = session.Get
1 using (ITransaction rs = session.BeginTransaction())
2 {
3 TplCustomer model = session.Get(typeof(TplCustomer),150218) as TplCustomer;
4 Console.WriteLine(model.LastName);
5 session.Clear();
6 var model_1 = session.Get
1 using (ITransaction rs = session.BeginTransaction())
2 {
3 TplCustomer model = session.Get(typeof(TplCustomer),150218) as TplCustomer;
4 model.LastName = "KingTao";
6 model.LastName = "KingHk";
7
8 session.Update(model);
9 rs.Commit();
10 session.Close();
11 Console.ReadLine();
12 } 1 using (ITransaction rs = session.BeginTransaction())
2 {
3 TplCustomer model = session.Get(typeof(TplCustomer),150218) as TplCustomer;
4 model.LastName = "KingTao";
5 session.Flush();
6 model.LastName = "KingHkp";
7
8 session.Update(model);
9 rs.Commit();
10 session.Close();
11 Console.ReadLine();
12 }
{
var model = session.CreateQuery("from TplCustomer where SeqId=:ps")
.SetParameter("ps", 150218).List
Console.WriteLine(model.FirstOrDefault().LastName);
var _model = session.CreateQuery("from TplCustomer where SeqId=:ps")
.SetParameter("ps", 150218).List
Console.WriteLine(_model.FirstOrDefault().LastName);
session.Close();
Console.ReadLine();
} 1 using (ITransaction rs = session.BeginTransaction())
2 {
3 var model = session.CreateQuery("from TplCustomer h where h.SeqId=150218")
4 .SetCacheable(true).List