我有两个类Office和FileDataObject定义为:
public class Office
{
public virtual string Name { get; set; }
public virtual string Phone { get; set; }
public virtual **FileDataObject** OfficePdf { get; set; }
}
public class FileDataObject
{
public virtual int? Id { get; set; }
public virtual ContentType ContentType {get;set;}
public virtual string FilePath {get;set;}
}
将映射定义为:
public class OfficeMap : ClassMap<Office>
{
Map(x => x.Name).Not.Nullable();
Map(x => x.Phone).Length(20);
References<FileDataObject>(x => x.OfficePdf).Cascade.All().Column("OfficePdfId").Nullable().ForeignKey("FK_Office_FileDataObject");
}
public class FileDataObjectMap : ClassMap<FileDataObject>
{
Id(x => x.Id).UnsavedValue(null).GeneratedBy.Native();
Map(x => x.ContentType);
Map(x => x.FilePath);
}
对于单个办公室,我只需要一个OfficePdf(FileDataObject),但如果没有为特定办公室上传pdf,它可能为NULL。 (所以0..1关系)
正确生成上述两种模式 表:Office-Column:OfficePdfId - &gt; mapping-&gt;表的PK-Id:FileDataObject。
请注意,我不希望Table:FileDataObject具有OfficeId列,因为其他实体也在使用FileDataObject。
虽然FileDataObject正确保存,但我面临的问题是 -
当用户更新现有的办公室pdf时,我很困惑是否为 首先删除现有的FileDataObject,然后创建一个新的或 更新现有的pdf将是更好的选择。
或者FNH有什么方法可以照顾它吗?
请你指导。
谢谢!
答案 0 :(得分:1)
除非您通过删除和重新创建来满足某些特定要求,否则最简单的方法就是更新现有的要求。您可以决定在Office
课程中创建或更新,因为它是FileDataObject
的所有者