我遇到ManyToMany映射问题。这就是我所拥有的:
public class Asset
{
public virtual int id {get;set;}
//other props
public virtual IList<Tag> Tags { get; set; }
}
public class Tag
{
public virtual int Id { get; set; }
public virtual string Description { get; set; }
public virtual string Slug { get; set; }
}
映射单向多对多
public class AssetMap : IAutoMappingOverride<Asset>
{
public void Override(AutoMapping<Asset> mapping)
{
mapping.HasManyToMany(x => x.Tags)
.Table("AssetTag")
.ParentKeyColumn("AssetId")
.ChildKeyColumn("TagId")
.Cascade.SaveUpdate();
}
}
我的第一个问题是:映射是否合适?
目前:
var asset = new Asset
{
//props
};
asset.Tags.Add(new Tag{...});
repository.Save(asset)
它插入了标签,但它没有在中间表“AssetTag”中插入任何标签
与
var asset = new Asset
{
//props
};
asset.Tags.Add(existing TAG);
repository.Save(asset)
它确实插入了资产,但它没有在中间表“AssetTag”中插入任何资产
感谢您的帮助, 丹
答案 0 :(得分:0)
映射是正确的。
我使用了几乎相同的结构,相同的映射,NHibernate 3.3.1.4000,SQL Server 2005,它工作正常。唯一的区别是我正在初始化主对象的构造函数中的列表。我也允许NH创建架构,包括。关系表。