gpt4 book ai didi

c# - NHibernate 带来旧数据

转载 作者:太空宇宙 更新时间:2023-11-03 11:26:19 27 4
gpt4 key购买 nike

我正在使用 c# 和 nhibernate 来访问数据库。我有两个或三个终端可以实现相同的操作,例如编辑或从同一个数据库中删除实体。我的问题是我的终端没有意识到另一个终端是否对数据库进行了任何更改,尽管我再次刷新执行查询的数据。我认为这是由于缓存。我试过 Flush() 和 Evict() 命令但没有结果。我希望有人能帮助我,对不起我糟糕的英语

-----信息已添加--------

这是一个 C# 桌面应用程序。我没有看到任何错误,问题是当我编辑或删除时,我需要知道该实体是否是从另一个终端修改的。当我从数据库中获取实体时,在您重新启动应用程序之前,我不会看到从另一个终端所做的更改。

session 由下一段代码创建:

[PossibleLongOperation]
private void DoConnectionWork(string nhibernateConfigPath)
{
String appPath = Directory.GetParent(Assembly.GetAssembly(GetType()).Location).FullName;
String serializablefilePath = Path.Combine(appPath, "configuration.serialized");
try
{
if (IsConfigurationFileValid(serializablefilePath))
{
Configuration = LoadConfigurationFromFile(serializablefilePath);
}
else
{
// configuration is immutable, store last returned value
Configuration = new Configuration();
Configuration.Configure(nhibernateConfigPath);
Configuration.AddAssembly(typeof(ObjectEntity).Assembly);
SaveConfigurationToFile(serializablefilePath, Configuration);
new SchemaUpdate(Configuration).Execute(true, true);
Console.WriteLine(@"Se solicitó la actualización de datos");
}
//NHibernateSchemaExport();
}
catch (Exception ex)
{
//if(File.Exists(serializablefilePath))
// File.Delete(serializablefilePath);
throw new GenericRepositoryException(string.Format("Error while configuring NHibernate: {0}.", ex.Message), ex);
}

try
{
SessionFactory = Configuration.BuildSessionFactory();
}
catch (Exception ex)
{
//if (File.Exists(serializablefilePath))
// File.Delete(serializablefilePath);
throw new GenericRepositoryException(string.Format("Error while building NH session factory: {0}.", ex.Message), ex);
}
}

------------已添加------------

这是我在 Clear() session 后得到的异常

09-02-2012 13:22:54|Error|Error:  
NHibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: 394, of entity: Model.Pedido
en NHibernate.Engine.StatefulPersistenceContext.CheckUniqueness(EntityKey key, Object obj) en d:\CSharp\NH\NH\nhibernate\src\NHibernate\Engine\StatefulPersistenceContext.cs:línea 688
en NHibernate.Event.Default.DefaultSaveOrUpdateEventListener.PerformUpdate(SaveOrUpdateEvent event, Object entity, IEntityPersister persister) en d:\CSharp\NH\NH\nhibernate\src\NHibernate\Event\Default\DefaultSaveOrUpdateEventListener.cs:línea 227
en NHibernate.Event.Default.DefaultSaveOrUpdateEventListener.EntityIsDetached(SaveOrUpdateEvent event) en d:\CSharp\NH\NH\nhibernate\src\NHibernate\Event\Default\DefaultSaveOrUpdateEventListener.cs:línea 186
en NHibernate.Event.Default.DefaultUpdateEventListener.PerformSaveOrUpdate(SaveOrUpdateEvent event) en d:\CSharp\NH\NH\nhibernate\src\NHibernate\Event\Default\DefaultUpdateEventListener.cs:línea 29
en NHibernate.Event.Default.DefaultSaveOrUpdateEventListener.OnSaveOrUpdate(SaveOrUpdateEvent event) en d:\CSharp\NH\NH\nhibernate\src\NHibernate\Event\Default\DefaultSaveOrUpdateEventListener.cs:línea 53
en NHibernate.Impl.SessionImpl.FireUpdate(SaveOrUpdateEvent event) en d:\CSharp\NH\NH\nhibernate\src\NHibernate\Impl\SessionImpl.cs:línea 2666
en NHibernate.Impl.SessionImpl.Update(Object obj) en d:\CSharp\NH\NH\nhibernate\src\NHibernate\Impl\SessionImpl.cs:línea 524
en Besnik.GenericRepository.NHibernate.NHibernateUnitOfWork.Update[TEntity](TEntity entity)
en Besnik.GenericRepository.GenericRepository`2.Update(TEntity entity)
en Services.Services.Implementation.PedidoServiceImpl.<>c__DisplayClass8.<Anular>b__7() en C:\Repositorio\ProyectosCasinoClub\SPMontaPlatosOK\Code\Services\Services\Implementation\PedidoServiceImpl.cs:línea 72
en Services.Transaction.Transaction.Execute(Action transactionalAction, Action`1 onException) en C:\Repositorio\ProyectosCasinoClub\SPMontaPlatosOK\Code\Services\Transaction\Transaction.cs:línea 32

最佳答案

您是否尝试通过 session.Clear() 清除 L1 session 缓存?

关于c# - NHibernate 带来旧数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9213440/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com