c# - NHibernate分层递归查询

标签 c# mysql sql nhibernate orm

我正在为我的应用程序使用 NHibernate ORM 和 MySql 数据库。我正在为我的类别使用简单的嵌套表模型。

我的表sql:

CREATE TABLE `cat` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `catId` int(11) DEFAULT '0',
  `dr` bit(1) DEFAULT NULL,
  `st` datetime DEFAULT NULL,
  PRIMARY KEY (`id`),
) ENGINE=MyISAM AUTO_INCREMENT=25 DEFAULT CHARSET=utf8;

我的类别:

   public class cat
    {
        [Key]
        public virtual int id { get; set; }
        public virtual int catId { get; set; }
        public virtual bool dr { get; set; }
        public virtual DateTime st { get; set; }

        [ForeignKey("catId")]
        public virtual IList<cat> cats { get; set; }
    }

我如何使用 NH 执行此查询:

select t2.* from (select id from cat where catId=0 and dr=1) t1 join 
cat t2 On(t1.id=t2.catId) where t2.st<Now() and t2.dr=1;

最佳答案

    using NHibernate;
    using NHibernate.Criterion;
    using NHibernate.Linq;
    using NHibernate.Transform;
    using System;
    using System.Collections.Generic;
    using System.Linq;

......

            var q2 = db.Query<cat>()
                .Where(x => x.catId== 0 && x.dr == true);

            q2 = from t1 in q2
                 join t2 in db.Query<cat>() on t1.id equals t2.catId
                 where t2.st< DateTime.Now && t2.dr== true
                 select t2;

            //for result list
            var myList = q2.ToList();

我可以使用 NHibernate 和 Linq 来执行该查询。也许它可以帮助某人。

关于c# - NHibernate分层递归查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41349147/

相关文章:

mysql - 从字符串mysql中检索数字

sql - 代码重构 SQL Server 数据库对象名称更改

mysql - 选择所有列,同时对一列执行 ifnull

c# - 以字节为单位的枚举大小

c# - 为什么未被引用的对象不被GC回收?

c# - 当所需的 XElement 名称直到运行时才知道时,如何从 XDocument 获取属性值?

sql - 两个不同数据库中的两个不同列之间具有外键关系

c# - 目标框架中缺少“WindowsBase”、 'PresentationCore'、 'PresentationFramework'

Mysql创建 View 并逐渐增加日期时间字段

php - mysql - 在逗号分隔的文本字段中查找匹配项