- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试使用公式来映射 ICollection 类型的属性,但是,无论我使用哪种方法来确定映射中的类型,nHibernate 都会引发错误。
No parameterless constructor defined for this object.
这是映射文件
this.Property(
x => x.AllChildIds,
m =>
{
m.Type<NHibernate.Type.ListType>();
m.Access(Accessor.Field);
m.Formula(@"(WITH [Child] ([Id], [ParentId])
AS (SELECT [hs0].[Id],
[hs0].[ParentId]
FROM [Client].[dbo].[HierarchySet] [hs0] (NOLOCK)
WHERE [hs0].[ParentId] IN (SELECT [hs1].[Id]
FROM [Client].[dbo].[HierarchySet] [hs1] (NOLOCK)
WHERE [hs1].[Id] = Id /* @p0 */)
UNION ALL
SELECT [Children].[Id],
[Children].[ParentId]
FROM [Client].[dbo].[HierarchySet](NOLOCK) AS [Children]
JOIN [Child]
ON [Children].[ParentId] = [Child].[Id])
SELECT [Child].[Id]
FROM [Child]
)");
});
这是我的课
private readonly ICollection<long> allChildIds;
public virtual IEnumerable<long> AllChildIds { get { return this.allChildIds; } }
如果我将映射文件中的类型更改为
m.Type<NHibernate.Type.GenericListType<NHibernate.Type.Int64Type>>();
然后我得到一个 Could not determine type for: System.Collections.Generic.IEnumerable
错误
我知道 SQL 很复杂,但肯定不会影响它?
编辑我的 NHibernate session 配置
private static Configuration ConfigureNHibernate()
{
var configration = new Configuration();
configration.SessionFactoryName("SessionFactoryName");
configration.DataBaseIntegration(db =>
{
db.Dialect<MsSql2005Dialect>();
db.Driver<SqlClientDriver>();
db.IsolationLevel = IsolationLevel.ReadUncommitted;
db.ConnectionStringName = "database";
db.BatchSize = 20;
db.KeywordsAutoImport = Hbm2DDLKeyWords.AutoQuote;
});
if (ConfigurationManager.AppSettings["nhibernate-cache"] != null)
{
configration.Cache(
x =>
{
x.DefaultExpiration = 300;
x.UseMinimalPuts = true;
x.RegionsPrefix = "client-";
x.Provider<SysCacheProvider>();
x.UseQueryCache = true;
});
}
var mapper = new ModelMapper();
mapper.AddMappings(typeof(MessageInMap).Assembly.GetTypes());
var domainMapping = mapper.CompileMappingForAllExplicitlyAddedEntities();
configration.AddMapping(domainMapping);
configration.AddAuxiliaryDatabaseObject(new SimpleAuxiliaryDatabaseObject(@"
CREATE VIEW [Children]
AS
WITH [Child] ([Id], [ParentId])
AS (
SELECT
[hs0].[Id],
[hs0].[ParentId]
FROM
[isnapshot.Client].[dbo].[HierarchySet] (NOLOCK) AS [hs0]
UNION ALL
SELECT
[Children_].[Id],
[Children_].[ParentId]
FROM
[isnapshot.Client].[dbo].[HierarchySet] (NOLOCK) AS [Children_]
JOIN [Child] ON [Children_].[ParentId] = [Child].[Id]
)
GO", "DROP VIEW [Children]"));
return configration;
}
最佳答案
您需要将其映射为组件集(包、列表等),而不是属性。然后使用子选择来获取它。
我的第一个假设是将其映射如下
c.Set(m => m.ChildrenIds,
x =>
{
x.Access(Accessor.Field);
x.Key(k => k.Column("ParentId"));
x.Subselect(@"WITH [Child] ([Id], [ParentId])
AS
(
SELECT
[hs0].[Id],
[hs0].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [hs0]
UNION ALL
SELECT
[Children].[Id],
[Children].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [Children]
JOIN
[Child] ON [Children].[ParentId] = [Child].[Id]
)
SELECT *
FROM [Child]");
},
x => x.Element(e => e.Column("Id")));
但是它不起作用,因为 WITH
子句不想在子选择中。生成的查询:
SELECT
childrenid0_.ParentId as ParentId0_,
childrenid0_.Id as Id0_
FROM ( WITH [Child] ([Id], [ParentId])
AS
(
SELECT
[hs0].[Id],
[hs0].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [hs0]
UNION ALL
SELECT
[Children].[Id],
[Children].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [Children]
JOIN
[Child] ON [Children].[ParentId] = [Child].[Id]
)
SELECT *
FROM [Child] ) childrenid0_
WHERE childrenid0_.ParentId=@p0;@p0 = 2 [Type: Int32 (0)]
所以在这种情况下,唯一的解决方案是创建一个 View ,并映射到它。
将数据库对象添加到配置
configuration.AddAuxiliaryDatabaseObject(new SimpleAuxiliaryDatabaseObject(@"
CREATE VIEW [Children]
AS
WITH [Child] ([Id], [ParentId])
AS (
SELECT
[hs0].[Id],
[hs0].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [hs0]
UNION ALL
SELECT
[Children].[Id],
[Children].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [Children]
JOIN [Child] ON [Children].[ParentId] = [Child].[Id]
)
SELECT *
FROM [Child]", "DROP VIEW [Children]"));
如果您正在使用 SchemaExport/SchemaUpdate 功能来创建/更新您的数据库架构 - NHibernate 将创建 View 。 如果您不使用 SchemaExport/SchemaUpdate 功能,则需要手动创建 View 。
CREATE VIEW [Children]
AS
WITH [Child] ([Id], [ParentId])
AS (
SELECT
[hs0].[Id],
[hs0].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [hs0]
UNION ALL
SELECT
[Children].[Id],
[Children].[ParentId]
FROM
[HierarchySet] (NOLOCK) AS [Children]
JOIN [Child] ON [Children].[ParentId] = [Child].[Id]
)
SELECT *
FROM [Child]
映射:
c.Set(m => m.ChildrenIds,
x =>
{
x.Access(Accessor.Field);
x.Key(k => k.Column("ParentId"));
x.Table("Children"); // or x.Subselect("select * from Children")
},
x => x.Element(e => e.Column("Id")));
关于c# - 将公式映射到 IEnumerable bycode,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15404376/
任何人都可以向我解释 IEnumerable 和 IEnumerator 之间的区别是什么, 以及如何使用它们? 谢谢!!! 最佳答案 通常,一个 IEnumerable是可以枚举的对象,例如列表或数
function TSomething.Concat(const E: IEnumerable>): IEnumerable; begin Result := TConcatIterator.Cr
我正试图找到解决这个问题的办法: 给定一个 IEnumerable> 我需要一个返回输入的方法/算法,但是如果多个 IEnumerable 具有相同的元素,则每个巧合/组只返回一个。 例如 I
我有一个有趣的问题:给定一个 IEnumerable , 是否有可能产生 IEnumerable> 的序列一次将相同的相邻字符串分组? 让我解释一下。 1。基本说明示例: 考虑以下 IEnumerab
我有课 public class Test { public void M1(IEnumerable> p) { } public void M2(IEnumerable)> p) {
我尝试解决下一个练习: 输入:整数列表 count >= 1;一些正整数 k 输出:此整数的所有可能元组,长度为 k ; 例如 输入: {1, 2}; k = 4 输出: { {1, 1, 1, 1
抱歉奇怪的标题。我想要实现的目标很简单: IEnumerable> listoflist; IEnumerable combined = listoflist.CombineStuff(); 例子:
公共(public)类项目 { ... public class Order { public List Items ... } public class Customer {
我有一个 IEnumerable>我想转换为单一维度集合的集合。是否可以使用通用扩展方法来实现这一点?现在我正在这样做以实现它。 List filteredCombinations = new Lis
我有一个 IEnumerable> CustomObject在哪里有一个 x (用作键(在本例中为 1 、 2 、 3 ))和 y值(value)。一些假数据: { { {1, 2}, {2, 4
我需要做的是选择嵌套元素列表,这是我的查询 returns IEnumerable>这是我的 linq 表达式: from a in (questions.Select(x => x.AnswerLi
如何使用 LINQ(或其他方式)将 IEnumerables 的 IEnumerable 拆分为一个平面 IEnumerable? 最佳答案 enumerable.SelectMany(x => x)
例如: public interface IEnumerable { IEnumerator GetEnumerator(); } //This interface allows the c
我对 Reflection.Emit 有疑问。我想要动态创建的类,它具有 ICollection 的简单实现。我定义的所有方法都很好,而不是接下来的两个: public IEnumerator Get
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Why was IEnumerable made covariant in C# 4? 我正在查看 MSDN
IEnumerator.MoveNext() 的实现是否预计会相对较快?或者如果“移动到下一项” 包括磁盘 IO、Web 请求或其他可能长时间运行的操作是否可以? 例如,我正在处理一个处理文档的项目,
以下代码创建了 List 的中间实例并在 yield 返回之前将值附加到它。有没有一种好的方法可以避免创建实例并直接 yield 返回单元格值? IEnumerable> GetStrValues()
我有两个 IEnumerable 对象,我想验证其中一个是否包含另一个的所有元素。 我正在使用 obj1.Intersect(obj2).Any() 但交集没有像我预期的那样工作。即使 obj2 中只
我正在尝试这个 MSDN page 上的例子.我试图更改 GetEnumerator 方法。我知道那似乎有些不对劲,但它符合要求然后就不会运行。错误是枚举器尚未启动,应该调用 MoveNext,但 它
我写过关于自定义 IEnumerator 的文章。从中生成 IEnumerable 的最简单方法是什么?理想的解决方案(一行代码)是是否有一些用于该目的的类。还是我必须自己创建? 最佳答案 不幸的是,
我是一名优秀的程序员,十分优秀!