- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有一个项目,从特定系统收集 XML 文件形式的数据(这些数据作为 Web 请求传入),将其转换为实体模型,并将其填充到数据库中以进行报告。
该项目使用以下软件(与此问题相关):
假设我有一个像这样的实体(简化):
public class Incident : Entity
{
public virtual string OriginatorSite { get; set; }
public virtual string DestinationSite { get; set; }
public virtual IncidentType IncidentType { get; set; }
public virtual TimeSpan TotalWaitTime { get; set; }
public virtual TimeSpan TotalActionTime { get; set; }
public virtual DateTime RegisterTime { get; set; }
public virtual DateTime CloseTime { get; set; }
public virtual DateDimension DateDimension { get; set; }
}
这是这样映射的:
public class IncidentMap : ClassMap<Incident>
{
public IncidentMap()
{
Id(c => c.Id);
Map(c => c.OriginatorSite);
Map(c => c.DestinationSite);
Map(c => c.IncidentType).CustomType<IncidentType>();
Map(c => c.TotalWaitTime);
Map(c => c.TotalActionTime);
Map(c => c.RegisterTime);
Map(c => c.CloseTime);
References<DateDimension>(c => c.DateDimension);
}
}
(Id来自Entity基类)
由于处理此类事情的人可能已经阅读过代码,因此我尝试在这里进行一些维度建模。我对这个主题很陌生,很可能做错了(tm),但我希望至少能从这种做事方式中获得一些好处;每个事件都引用一个 DateDimension 对象,如下所示:
public class DateDimension : Entity
{
public virtual int DayOfMonth { get; set; }
public virtual int Weekday { get; set; }
public virtual string WeekdayName { get; set; }
public virtual int Week { get; set; }
public virtual int MonthPart { get; set; }
public virtual int Month { get; set; }
public virtual string MonthName { get; set; }
public virtual int Quarter { get; set; }
public virtual int Year { get; set; }
}
DateDimension 表已填充 - 我的系统从未真正在此处创建任何记录。这些是在实际使用之前生成的 - 系统中每个相关日期一行。这是我的系统的功能之一。它 promise 每个可能的日期都会有一排。如果其中一个缺失,那将是一场灾难性的失败。
如果您是维度建模的新手,您可能会问为什么要这样做,就像我两天前撰写本文时一样。
嗯,我会有很多每个日期的事件记录。因此,DateDimension 表将比 Incident 表小很多,并允许我使用 NHibernate LINQ 执行原本会很困难的操作。例如这样的事情:
var IncidentsPerWeekday = _incidentRepository
.GroupBy(i => i.DateDimension.Weekday)
.Select(g => new Tuple<int,int>(g.Key, g.Count()))
.ToList();
给我一份群组列表,告诉我这些事件如何在工作日进行划分。当然,可以在此处添加许多不同的维度,使我能够围绕一堆不同的参数调整报告并创建有趣的报告。
但是,有一个小烦恼,在这里我们终于找到了真正的问题。
DateDimension 有一个主键,它基本上是它以特定格式表示的日期。对于 2011 年 4 月 30 日,它看起来像这样:
20110430
这是通过在 NHibernate 中使用自定义 IIdentifierGenerator 来完成的。由于每个日期我们只有一条记录,因此我认为这是一种相当简洁的方法。
此外,这也是让新事件实体了解其相关 DateDimension 引用的外键的快速方法。有些工厂会知道我们从 Incident.RegisterTime DateTime 中提取此 key ,然后将其填充到 DateDimension_id 列中。
但是,我似乎找不到办法做到这一点。 Incident.DateDimension 正确地要求实体引用。这意味着我必须从数据库加载它(对吗?)。在某些导入场景中,我需要在尽可能短的时间内将大量事件实体插入数据库,这可能会太慢。
当然,对于这个特定的示例,我可能可以通过每次插入实体时执行一些自定义 SQL 来做到这一点,并允许 NULL 引用。这并不理想,但它可以工作。
但是,有没有办法直接指定 DateDimension 引用的外键,而不是使用对真实的存储引用对象的引用来设置它?
这肯定能让我摆脱巨大的头痛!
预先感谢您的任何见解!
最佳答案
您可以使用 ISession.Load 方法来执行此操作。
myIncident.DateDimension = mySession.Load("20110430");
这将为 DateDimension 创建代理,从而避免数据库访问。顺便说一下,如果您访问代理上除 key 之外的任何属性,它将被加载。
关于nhibernate - 是否可以直接在 NHibernate 中设置引用的外键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4773758/
我一直在为初学者阅读 nhibernate 3.0 并阅读了一些常见错误(我犯了一些错误) 我想知道将一个或多个记录设为只读有哪些策略。现在我取回所有行并循环遍历它们,使它们通过 session.Re
我们有一个使用 NHibernate 的相当健壮的系统,我们正在从单个数据库服务器迁移到拥有两台服务器,一台用于管理,另一台用于我们面向公众的网站。这主要是为了让我们可以使用不会影响当前站点的工作流来
我在尝试构建一个时遇到以下错误 session 工厂: PersistenceTests.Can_Map_Orders_To_Database : Failed System.IndexOutOfRa
如果客户有很多订单附加到他们。您将如何使用 NHibernate 延迟加载订单列表。 是不是需要设置映射文件?任何帮助或示例都会很棒。 最佳答案 Chris 的建议是我会怎么做,但是如果您想在运行时执
我正在尝试使用 HQL 对一个简单的查询进行分页,并将总行数作为同一查询的一部分进行检索。 我的查询很简单... var members = UnitOfWork.CurrentSession.Cre
我有旧版数据库,存储的日期表示无日期为9999-21-31, 列Till_Date的类型为DateTime not-null="true"。 在应用程序中,我要构建持久化类,将no-date表示为nu
您可以指定命名空间和程序集以使用 HBM 文件顶部的类型: 您可以在同一个映射文件中使用来自多个程序集/命名空间的类型,如果可以,这样做的语法是什么? 最佳答案 您可以从 HBM 文件的顶部删除默认
如何强制 NHibernate 在多对多集合上执行 RIGHT 外连接或 INNER 连接而不是 LEFT 外连接? 我想这样做的原因是因为过滤应用于集合元素。使用左连接,您将获得与未过滤查询相同的返
我们开始在我的工作场所使用NHibernate,包括从映射生成模式。我们的DBA想要的一件事是主键和外键关系的名称一致。我已经能够设置FK约束名称,但是在的文档中看,它似乎不存在命名主键约束的方法。
我需要NHibernate来执行这样的查询: SELECT * FROM Users ORDER BY Func(FirstName, LastName) Standart NHibernate Or
假设在一个实体中有属性 id、用户名、年龄、地址。现在我只想要 id 和 username 并使用此代码。 投影可以从查询中返回实体列表以外的内容。 var proj = Projections.Pr
我花了很长时间,但我终于让 nHibernate 的 Hello World 工作了。在我做了“延迟加载”之后它起作用了。老实说,我无法告诉您为什么这一切都有效,但确实如此,现在我正在阅读您不需要延迟
假设您有两个类,Person 和 Address。 Person 有一个对 Address 的引用,如下所示: public class Person { public virtual Addre
我在 NHibernate 引用文档 中阅读第 10 章“只读实体”如下: http://nhibernate.info/doc/nh/en/index.html#readonly 但不幸的是我不知道
有谁知道 NHibernate 是否支持从存储过程返回输出参数?我在文档中进行了搜索,但无法真正找到任何可以确认的内容。 最佳答案 我面临同样的问题。 NHibernate 不允许您以这种方式使用存储
简而言之,什么工作得更快: SessionFactory 预编译 XML 配置,或 流畅的NHibernate提供 以编程方式配置? 最佳答案 我个人的经验是,Configuration 对象的构建(
我的域类具有如下所示的集合: private List _foos = new List(); public virtual ReadOnlyCollection Foos { get { retur
当我有一个带有一对多子集合的实体对象时,我需要查询一个特定的子对象,是否有我还没有想出的功能或一些巧妙的模式来避免 NHibernate获取整个子集合? 例子: class Parent {
在我的域中,员工和部门具有一对多的双向关系;为了让子员工同步这个,我有一个“内部”访问字段,用于部门中员工的集合(NHibernate 的 Iesi),否则它将是只读公共(public)的。像这样:
我有一个 nhibernate 自定义类型,我想用 Fluent NHibernate 映射它。 HBM 映射如下所示。 Services.Data.DateConventionTyp
我是一名优秀的程序员,十分优秀!