本文整理汇总了C#中IEventSource.GetEntityPersister方法的典型用法代码示例。如果您正苦于以下问题:C# IEventSource.GetEntityPersister方法的具体用法?C# IEventSource.GetEntityPersister怎么用?C# IEventSource.GetEntityPersister使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IEventSource
的用法示例。
在下文中一共展示了IEventSource.GetEntityPersister方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: SaveWithGeneratedId
/// <summary>
/// Prepares the save call using a newly generated id.
/// </summary>
/// <param name="entity">The entity to be saved </param>
/// <param name="entityName">The entity-name for the entity to be saved </param>
/// <param name="anything">Generally cascade-specific information. </param>
/// <param name="source">The session which is the source of this save event. </param>
/// <param name="requiresImmediateIdAccess">
/// does the event context require
/// access to the identifier immediately after execution of this method (if
/// not, post-insert style id generators may be postponed if we are outside
/// a transaction).
/// </param>
/// <returns>
/// The id used to save the entity; may be null depending on the
/// type of id generator used and the requiresImmediateIdAccess value
/// </returns>
protected virtual object SaveWithGeneratedId(object entity, string entityName, object anything, IEventSource source, bool requiresImmediateIdAccess)
{
IEntityPersister persister = source.GetEntityPersister(entityName, entity);
object generatedId = persister.IdentifierGenerator.Generate(source, entity);
if (generatedId == null)
{
throw new IdentifierGenerationException("null id generated for:" + entity.GetType());
}
else if (generatedId == IdentifierGeneratorFactory.ShortCircuitIndicator)
{
return source.GetIdentifier(entity);
}
else if (generatedId == IdentifierGeneratorFactory.PostInsertIndicator)
{
return PerformSave(entity, null, persister, true, anything, source, requiresImmediateIdAccess);
}
else
{
if (log.IsDebugEnabled)
{
log.Debug(string.Format("generated identifier: {0}, using strategy: {1}",
persister.IdentifierType.ToLoggableString(generatedId, source.Factory),
persister.IdentifierGenerator.GetType().FullName));
}
return PerformSave(entity, generatedId, persister, false, anything, source, true);
}
}
示例2: SaveWithRequestedId
/// <summary>
/// Prepares the save call using the given requested id.
/// </summary>
/// <param name="entity">The entity to be saved. </param>
/// <param name="requestedId">The id to which to associate the entity. </param>
/// <param name="entityName">The name of the entity being saved. </param>
/// <param name="anything">Generally cascade-specific information. </param>
/// <param name="source">The session which is the source of this save event. </param>
/// <returns> The id used to save the entity. </returns>
protected virtual object SaveWithRequestedId(object entity, object requestedId, string entityName, object anything, IEventSource source)
{
return PerformSave(entity, requestedId, source.GetEntityPersister(entityName, entity), false, anything, source, true);
}
示例3: MergeTransientEntity
private object MergeTransientEntity(object entity, string entityName, object requestedId, IEventSource source, IDictionary copyCache)
{
IEntityPersister persister = source.GetEntityPersister(entityName, entity);
object id = persister.HasIdentifierProperty ? persister.GetIdentifier(entity, source.EntityMode) : null;
object copy = null;
if (copyCache.Contains(entity))
{
copy = copyCache[entity];
persister.SetIdentifier(copy, id, source.EntityMode);
}
else
{
copy = source.Instantiate(persister, id);
((EventCache)copyCache).Add(entity, copy, true); // before cascade!
}
// cascade first, so that all unsaved objects get their
// copy created before we actually copy
//cascadeOnMerge(event, persister, entity, copyCache, Cascades.CASCADE_BEFORE_MERGE);
base.CascadeBeforeSave(source, persister, entity, copyCache);
CopyValues(persister, entity, copy, source, copyCache, ForeignKeyDirection.ForeignKeyFromParent);
try
{
// try saving; check for non-nullable properties that are null or transient entities before saving
this.SaveTransientEntity(copy, entityName, requestedId, source, copyCache);
}
catch (PropertyValueException ex)
{
string propertyName = ex.PropertyName;
object propertyFromCopy = persister.GetPropertyValue(copy, propertyName, source.EntityMode);
object propertyFromEntity = persister.GetPropertyValue(entity, propertyName, source.EntityMode);
IType propertyType = persister.GetPropertyType(propertyName);
EntityEntry copyEntry = source.PersistenceContext.GetEntry(copy);
if (propertyFromCopy == null || !propertyType.IsEntityType)
{
log.InfoFormat("property '{0}.{1}' is null or not an entity; {1} =[{2}]", copyEntry.EntityName, propertyName, propertyFromCopy);
throw;
}
if (!copyCache.Contains(propertyFromEntity))
{
log.InfoFormat("property '{0}.{1}' from original entity is not in copyCache; {1} =[{2}]", copyEntry.EntityName, propertyName, propertyFromEntity);
throw;
}
if (((EventCache)copyCache).IsOperatedOn(propertyFromEntity))
{
log.InfoFormat("property '{0}.{1}' from original entity is in copyCache and is in the process of being merged; {1} =[{2}]", copyEntry.EntityName, propertyName, propertyFromEntity);
}
else
{
log.InfoFormat("property '{0}.{1}' from original entity is in copyCache and is not in the process of being merged; {1} =[{2}]", copyEntry.EntityName, propertyName, propertyFromEntity);
}
// continue...; we'll find out if it ends up not getting saved later
}
// cascade first, so that all unsaved objects get their
// copy created before we actually copy
base.CascadeAfterSave(source, persister, entity, copyCache);
CopyValues(persister, entity, copy, source, copyCache, ForeignKeyDirection.ForeignKeyToParent);
return copy;
}