- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
FluentNHibernate 的自动映射是否支持通过约定创建多列唯一约束?
我可以轻松地创建单列唯一约束:
public void Apply(IPropertyInstance instance)
{
if(instance.Name.ToUpper().Equals("NAME"))
instance.Unique();
}
使用验收标准仅查找 ReferenceEntity
类型。
我现在有一个实体,我想为其创建多列唯一约束。我计划用一个属性来装饰实体的属性,以指示它们构成同一唯一键的一部分,即:
public class Foo : Entity
{
[Unique("name_parent")]
public virtual string Name { get; set; }
public virtual string Description { get; set; }
[Unique("name_parent")]
public virtual Bar Parent { get; set; }
}
并让约定查找这些属性并在共享相同唯一键的所有字段中创建一个唯一键。
IProperyConvention
接口(interface)允许您在特定实例(列)上指定 Unique
,但对其他列不可见。
发布这个的过程帮助我思考了更多,所以我写下了这个:
var propertyInfo = ((PropertyInstance)(instance)).EntityType.GetMember(instance.Name).FirstOrDefault();
if (propertyInfo != null)
{
var attributes = propertyInfo.GetCustomAttributes(false);
var uniqueAttribute = attributes.OfType<UniqueAttribute>().FirstOrDefault();
if (uniqueAttribute != null)
{
instance.UniqueKey(uniqueAttribute.Key);
}
}
单步执行代码,它会点击 instance.UniqueKey(...)
行两次(如预期的那样),但是创建的约束 (pgsql);
ADD CONSTRAINT foo_name_key UNIQUE(name);
在我预料之中
ADD CONSTRAINT name_parent UNIQUE(name, bar);
在 AutoMap 配置中使用 Override()
方法时,我可以指定正确的唯一键:
.Override<Foo>(map => {
map.Map(x => x.Name).UniqueKey("name_parent");
map.Map(x => x.Description);
map.References(x => x.Parent).UniqueKey("name_parent");
})
这可能是自动映射器的问题,不确定。仍然不理想,因为它不是通过属性修饰通用的,但现在数据模型反射(reflect)了域需求。
最佳答案
当我这样做时,我创建了 2 个约定,一个是 AttributePropertyConvention,另一个是 IReferenceConvention。我的属性看起来像这样:
public class UniqueAttribute : Attribute
{
public UniqueAttribute(string uniqueKey)
{
UniqueKey = uniqueKey;
}
public string UniqueKey { get; set; }
public string GetKey()
{
return string.Concat(UniqueKey, "Unique");
}
}
我的属性(property)惯例:
public class UniquePropertyConvention : AttributePropertyConvention<UniqueAttribute>
{
protected override void Apply(UniqueAttribute attribute, IPropertyInstance instance)
{
instance.UniqueKey(attribute.GetKey());
}
}
最后是引用约定:
public class UniqueReferenceConvention : IReferenceConvention
{
public void Apply(IManyToOneInstance instance)
{
var p = instance.Property.MemberInfo;
if (Attribute.IsDefined(p, typeof(UniqueAttribute)))
{
var attribute = (UniqueAttribute[])p.GetCustomAttributes(typeof(UniqueAttribute), true);
instance.UniqueKey(attribute[0].GetKey());
}
}
}
希望这适用于您的场景。
关于c# - 通过约定的多列唯一约束 FluentNHibernate 自动映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5972424/
假设我有一个函数,例如 f(x,y)但y参数是可选的。设置y的首选方式是什么?作为可选参数?对我有用的一种选择: function f(x, y=nothing) # do stuff
在学习核心动画时,我很快就了解到,如果你做得不对,你会得到非常奇怪的未定义行为。为此,我有几个问题可以帮助我从概念上更好地理解它。 我的 NSView 子类在其 init.h 中声明以下内容:该 Vi
我一直在尝试学习 ClojureScript,并偶然发现了一些非常神秘的函数名称。 例如: (.-length str) 来自 om 文档: (defn add-contact [data owner
我对此很好奇。我最近想到使用大括号来隔离代码段,以进行可视化组织,并将变量隔离到特定范围(如果只是为了防止它们在较大的函数中混淆 Eclipse 中的建议)。例如: public void start
所以我进行了一些搜索,但在 Google 或 PEP 上找不到任何讨论此问题的内容。 我正在使用 tkinter 做一个项目,我有一个文件,它是项目的一部分,只有 200 行代码(不包括所有注释掉的代
根据某种不成文的约定,所有 API key 都是十六进制数字吗? 最佳答案 对一些半随机数据(例如时间戳 + 用户 ID + key )进行 md5 哈希是一种快速生成难以猜测的固定长度 key 的方
在 C 中,如果编译器想要提供实现定义的标识符(语言扩展、内在函数、伪函数和伪宏,基本上任何不是语言标准保留关键字但也不是常规函数的东西)惯例是名称以下划线为前缀;据了解,代码不应出于正常目的使用此类
Java Bean 的约定之一是: setter 的返回类型必须是 void。 或者至少大多数人是这么说的。我的问题是:它真的必须无效吗?我喜欢返回 "this" 而不是 "void" 因为我可以像这
我对 Java 编码风格有疑问。 我编码: public class Pattern { public Pattern(...) { ... } public static List
我有一个关于 Java servlet 约定的问题。在查看 servlet 的任何教程时,无论是 Eclipse、NetBeans 等,它们总是让您创建一个 index.jsp 页面。创建页面后,他们
在 python 中,当变量名与保留字冲突时(如 class、in、default 等),PEP8约定规定应使用尾随下划线(class_、in_、default_)。 对于相同的情况,共享最多的 ja
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 5 年前。 Improve
Java 存储预定义字符串集的主要约定是什么?现在我有一个包含我使用的所有字符串的类,但感觉确实有更好的方法来做到这一点。 这就是我在 my_strings.java 类中所做的 public fin
我经常需要检索结果并按给定列访问它们。 有没有一种方法可以不用每次都遍历整个数据集来编写它? 我研究了各种 PDO 获取模式,但没有发现比这更简单的模式。谢谢。 function get_groups
所以我正在制作这个 android 应用程序,它需要从用户提供的 CSV 文件中读取数据。 CSV 文件在台式电脑上编辑起来更舒服,所以我在应用程序中没有编辑器,它是“只读”的;我假设手机的 SD 卡
我正在编写一个文件,该文件是 npycurses module 的子类 npycurses.ActionFormV2 ,我正在覆盖 beforeEditing method ,所以当我整理我的文件时,
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我正在开发一个可在 iPhone、iPad 和其他移动设备上运行的网页。我很好奇是否有关于移动设备 CSS 最佳实践的资源。 我试过搜索,但想出了随机网站 with tidbits of inform
我发现开始编程时最大的挑战之一是掌握文件路径。例如,当您引用目录结构中同一级别的文件夹中的路径时,您将看到: /folder/style.css 或 文件夹/style.css等 当您引用不同的文件时
如果我有如下函数: def foo(): return 1, 2 我通常会这样调用函数: g, f = foo() 但是,如果我从不打算使用返回的第二个值,是否有一种调用函数的方法可以明确说明
我是一名优秀的程序员,十分优秀!