首页
学习
活动
专区
圈层
工具
发布

在NHibernate的单表继承模式下通过父类Repository查询子类

在NHibernate中经常遇到继承与关系数据库的ORMapping的问题,我之前的一篇博客(http://www.cnblogs.com/studyzy/archive/2011/08/16/2140675...使用单表继承可以不用Join多个表查询效率高,而且在Domain Model的属性提示到父类或者下降到子类时,数据库模型不用更改。...下面分别用QueryOver、Criteria和HQL来说明: QueryOver查询Employee表中的所有Teacher: Session.QueryOver().Where(...a =>a.GetType() == typeof (Teacher)).List(); 这里需要注意的是,条件中使用的是a.GetType()==typeof(Teacher),但是不能使用a is...必须这么写,不能写成大写的Class,也不能换成其他字,只有这样才能让NHibernate理解,并正确返回结果。

81520

NHibernate中关于Inverse的理解和使用

在使用NHibernate进行数据库操作的时候,比如数据插入的时候,经常用到级联功能,比如最常见的就是一个订单对应多个明细行,在保存订单时只需要Save订单对象即可,订单下的所有明细行会级联保存。...默认使用Order的属性作为有效的关联,换句话说,只需要把OrderItem一个个的加入到Order的Items集合即可,最终结果不需要关心OrderItem中引用的Order到底是什么或者为空。...【注意:这里是说最终结果,而不是中间结果,在Insert OrderItem的时候,其OrderId为该对象对应的Order对象的Id,如果该Order对象未保存,则OrderId为null,如果是已保存的...所以一般建议在Mapping时设置Inverse为True。对应的,在Code中也需要设置OrderItem对Order的引用。 Inverse更大的用处是在ManyToMany的时候。...语句,当然如果把C#代码中的6行和7行去掉,结果也是正确的,因为现在系统只认Emp中的Awards集合了。

91030
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL Server字符串左匹配

    最常见的一个例子就是在搜索框中,用户输入了一部分关键字,系统可以通过用户的输入进行左匹配,找出相关的结果列出来。...使用左匹配的好处是可以使用到SQL Server中对该字段建立的索引,使得查询效率很高,但是不好的SQL语句仍然会导致索引无法使用。...假设我们现在有个表YCMRSALE,其中有个字段MATNR存储了料号信息,如果我们要从这个表中查询出以AB开头的料号,如果使用NHibernate,那么我们常用的写法有: //QueryOver的写法...条件语句: where ycmrsale0_.Matnr like 'AB%' 如果使用EntityFramework,那么查询的C#代码也和NHibernate类似: var result = bwEntities.YCMRSALEs.Select...Where条件: WHERE this_.Matnr like @p0 escape '~';@p0 = '~%00%' 以上说的都是在ORMapping的工具中进行左匹配查询,如果我们要在SQL语句中直接进行查询还有一种写法就是用

    1.3K10

    NHibernate 缓存

    在 NHibernate 的参考文档中, 对 ISession 的描述如下: A single-threaded, short-lived object representing a conversation...一级缓存测试 一级缓存缓存无需配置, 默认支持, 因此, 在使用 session 查询对象, 如果仅仅是根据 id 加载指定的对象, 需要使用 session 的 Get 或 Load 方法, 这样可以充分利用...这些实现都是 2、 配置指定的实体类、集合启用二级缓存缓存 在 hibernate.cfg.xml 文件中添加下面的设置: 在实体类的 hbm 映射文件中配置使用二级缓存, 不过在 hibernate.cfg.xml 文件中统一配置是推荐的做法。...以上是在项目中用到的二级缓存相关知识的整理, 肯定不完整, NHibernate 的缓存还有更多的地方需要挖掘。

    1.1K11

    在Exce中使用带有动态数组公式的切片器

    如下图2和图3所示,使用SUBTOTAL函数统计可见行数, 图2 图3 在单元格B9中的公式为: =SUBTOTAL(103,表1) 公式中,参数103告诉SUBTOTAL在统计时忽略隐藏行。...图4 图5 在单元格C3中的公式为: =SUBTOTAL(103,[@示例列表]) 创建切片 选择表中的任意单元格。单击功能区“插入”选项卡“筛选器”组中的“切片器”。...在“插入切片器”对话框中选择所需要的列,如下图6所示,单击“确定”。 图6 结果如下图7所示。 图7 此时,单击切片器,将筛选列表数据。...将切片器连接到公式 使用FILTER函数来仅返回表中的可见行,即“标志”列为1的行,如下图8所示。...图8 单元格B13中的公式为: =FILTER(表1[示例列表],表1[标志]=1) 如果不想在原表中添加额外列(如本例中的“标志”列),则可以使用LAMBDA函数,如下图9所示。

    2K10

    在java中构建高效的结果缓存

    缓存是现代应用服务器中非常常用的组件。除了第三方缓存以外,我们通常也需要在java中构建内部使用的缓存。那么怎么才能构建一个高效的缓存呢? 本文将会一步步的进行揭秘。...使用HashMap 缓存通常的用法就是构建一个内存中使用的Map,在做一个长时间的操作比如计算之前,先在Map中查询一下计算的结果是否存在,如果不存在的话再执行计算操作。...虽然这样的设计能够保证程序的正确执行,但是每次只允许一个线程执行calculate操作,其他调用calculate方法的线程将会被阻塞,在多线程的执行环境中这会严重影响速度。...从而导致使用缓存可能比不使用缓存需要的时间更长。...FutureTask表示一个计算过程,我们可以通过调用FutureTask的get方法来获取执行的结果,如果该执行正在进行中,则会等待。 下面我们使用FutureTask来进行改写。

    2.6K30

    Power Pivot中筛选条件的使用

    (一) 定义 在Power Pivot中,在大部分时间里,筛选是作为一个主要的功能运用到各个地方,筛选上下文,行上下文都和筛选相关。 (二) 可能涉及的函数 Filter 含义:根据条件筛选。...All 含义:忽略指定的维度条件。 AllExpect 含义:忽略除保留维度外的其他条件。 Calculate 含义:根据条件进行计算。大部分的筛选器最终需要与本函数进行组合运算。...,filter('表'="张三")) 我们先来看下几个计算的差异(数据透视表): 行标签 固定条件求和 筛选条件求和 忽略条件求和 忽略多条件求和 李四 100 100 王五 100 100 张三...涉及上下文 忽略条件求和 在筛选时忽略字段筛选如果全部忽略相当于不涉及上下文,也就和固定条件求和一样 ---- 忽略多条件求和,因为calculate本身不存在绝对的筛选,所以条件all不产生作用,所以函数...在使用忽略函数的时候,要根据被筛选filter里面的实际筛选条件来定义,所以忽略学科和忽略学科除外都是错误的。因为filter函数内部没有进行学科的实际筛选。也就不存在忽略的问题。 (四)总结 ?

    6.2K20

    NHibernate 缓存

    在 NHibernate 的参考文档中, 对 ISession 的描述如下: A single-threaded, short-lived object representing a conversation...一级缓存测试 一级缓存缓存无需配置, 默认支持, 因此, 在使用 session 查询对象, 如果仅仅是根据 id 加载指定的对象, 需要使用 session 的 Get 或 Load 方法, 这样可以充分利用...这些实现都是 2、 配置指定的实体类、集合启用二级缓存缓存 在 hibernate.cfg.xml 文件中添加下面的设置: 在实体类的 hbm 映射文件中配置使用二级缓存, 不过在 hibernate.cfg.xml 文件中统一配置是推荐的做法。...以上是在项目中用到的二级缓存相关知识的整理, 肯定不完整, NHibernate 的缓存还有更多的地方需要挖掘。

    79310

    在zabbix中实现发送带有图片的邮件和微信告警

    李白《春夜宴从弟桃花园序》 ---- 1 python实现在4.2版本zabbix发送带有图片的报警邮件 我们通常收到的报警,都是文字,是把动作中的消息内容当成了正文参数传给脚本,然后邮件或者微信进行接收...msg.attach(html) #使用attach方法将HTML添加到msg实例中 msg.attach(graph) #使用attach方法将图片添加到msg实例中 msg...打开管理中的用户,点击需要设置邮件告警的用户,然后在报警媒介中添加报警媒介,在弹框中选择刚才定义的类型,然后填写想要发送的邮箱地址,最后添加 ?...2 python实现在4.2版本zabbix发送带有图片的微信告警 2.1 实现思路 ?...打开管理中的用户,点击需要设置邮件告警的用户,然后在报警媒介中添加报警媒介,在弹框中选择刚才定义的类型,然后填写企业微信中创建的部门id,最后添加 ?

    3.5K51

    在 SQL 中,如何使用子查询来获取满足特定条件的数据?

    在 SQL 中,可以使用子查询来获取满足特定条件的数据。子查询是嵌套在主查询中的查询语句,它返回一个结果集,可以用来过滤主查询的结果。...下面是使用子查询来获取满足特定条件的数据的一般步骤: 在主查询中使用子查询,将子查询的结果作为条件。 子查询可以在主查询中的 WHERE 子句、FROM 子句或 HAVING 子句中使用。...子查询可以返回单个值或多个值,具体取决于使用的运算符和子查询的语法。 以下是一些示例: 使用子查询在 WHERE 子句中过滤数据: SELECT column1, column2, ......FROM (SELECT column FROM table WHERE condition) AS temp_table; 使用子查询在 HAVING 子句中过滤数据: SELECT column1,...FROM table GROUP BY column1 HAVING column1 > (SELECT AVG(column1) FROM table); 请注意,子查询的性能可能会较低,因此在设计查询时应谨慎使用

    9.8K10

    使用VS2015和Nhibernate实现与MySql数据库连接,实现增删改查操作

    ,MySQL-FRONT ,Connector/Net(选择.Net&Mono) Nhibernate包可以在VS2015中下载 ,对MySql操作,我用的是MySQL-FRONT,注意要想实现和数据库的链接...先写一个简单的给你定义的数据库中添加一条元素的代码:(不使用Nhibernate的) 前提:先把该用的dll文件,添加到引用里面去不然,会连接不成功,之前下载的Connector/Net(选择.Net&...Nhibernate包来实现一个很简单的对数据增删改查的操作,这一次需要用到我们之前下载的Nhibernate包里面的文件,全部dll文件引入之后,“引用”下面应该是这样的: ?...帮助类,使用Nhibernate连接数据库,用来得到sessionFactory,然后使用sessionFactory里面的session去操作数据库,代码如下: using System; using...//我们之后就是使用session来进行操作数据库 } } } 4.在Manger文件里新建一个名为APengChaoManger

    1.9K30

    在Google搜索结果中显示你网站的作者信息

    前几天在卢松松那里看到关于在Google搜索结果中显示作者信息的介绍,站长也亲自试了一下,目前已经成功。也和大家分享一下吧。...如果您希望您的作者信息出现在自己所创建内容的搜索结果中,那么您需要拥有 Google+ 个人资料,并使用醒目美观的头像作为个人资料照片。...然后,您可以使用以下任意一种方法将内容的作者信息与自己的个人资料关联,以便进行验证。Google 不保证一定会在 Google 网页搜索或 Google 新闻结果中显示作者信息。...您的电子邮件地址将会显示在您的 Google+ 个人资料的以下网站的撰稿者部分。如果您不希望公开自己的电子邮件地址,可以更改链接的公开程度。...要了解 Google 能够从您的网页提取哪些作者数据,可以使用结构化数据测试工具。 以上方法来自 Google搜索结果中的作者信息 站长使用的是 方法2,操作完以后,4天才显示作者信息。

    4.8K10

    shell脚本中的if条件语句介绍和使用案例

    #前言:在生产工作中if条件语句是最常使用的,如使用来判断服务状态,监控服务器的CPU,内存,磁盘等操作,所以我们需要熟悉和掌握if条件语句。 简介 if条件语句,简单来说就是:如果,那么。...> 可以是test、[]、[[]]、(())等条件表达式,每一个if条件语句都是以if开头,并带有then,最后以fi结尾 #例子: [root@shell scripts]# cat if.sh #...都要带有then,最后结尾的else后面没有then #简单记忆 如果 那么 我就嫁给你 或者如果 那么...root@shell scripts]# sh if2.sh 3 input 3 success [root@shell scripts]# sh if2.sh 4 input failure 4.if条件语句的使用案例...netstat或ss过滤然后使用wc统计,进行判断,如果结果大于0,就表示运行,否则就发邮件报警然后启动服务 [root@shell scripts]# cat web.sh #!

    10.9K40
    领券