首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

NHibernate 多对多映射的数据更新

NHibernate 多对多映射的数据更新 最近在用 NHibernate 做多对多更新时突然发现 NHibernate 更新的策略很差, 对多对多关系的更新居然是先全部删除再插入全部数据, 感觉非常奇怪..., 再添加一个新的角色, NHibernate 生成的 SQL 语句如下(仅包含对关系表 User_Role 的操作): DELETE FROM [User_Role] WHERE [UserId] =...Tip: Use set for many-to-many associations 发现了解决方案, 将多对多的映射的 bag 改为用 set , 问题终于得到了解决, 改过后的映射如下: Set(...不只是多对多, 如果你的集合需要更新, NHibernate 推荐的是: 19.5.2....sess.Flush(); 由此可见, bag 在多对多映射更新时性能较差, 如果不需要更新,则可以放心使用, 在需要更新时则 set 是更好的选择。

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

    如何使用Fluent Nhibernate中的Automapping进行OR Mapping映射

    由于在项目中使用了NHibernate来作为ORMapping构建数据访问层,那么就必须要配置Object和DataTable的映射。...使用Fluent NHibernate的最大好处是降低了出错的机会,因为Fluent Nhibernate的配置是使用C#来编写,可以智能感知,而且还能编译,不像原始的XML配置,写错了都不知道。...我们只需要定义好映射的规则,就可以不对每个表和类分别编写映射配置,而是按照规则进行自动的Mapping工作。这样在修改class或者DataTable时,只需要修改类和表即可,不需要再修改配置文件。...Hilo值的主键生成方式,使用一个表HIBERNATE_UNIQUE_KEY存储每个表的流水。...TYPE的列 } } 然后就是关于DiscriminateColumn中的值如何映射成对应的Subclass,需要实现ISubclassConvention接口,代码如下: public class

    1.1K10

    返回非空值函数LastnonBlank的第2参数使用方法

    非空值函数LastnonBlank第2参数使用方法 LastnonBlank(,) 参数 描述 column 列名或者具有单列的表,单列表的逻辑判断 expression...如果我们第二参数只写一个常数,则等同于返回列表的最大值,主要差异表现在汇总合计上。 有2张表,一张是余额表,另外一张是日历表,并做关系链接。 ? ? 我们来看下3种写法,返回的不同结果。...解释:带常数的LastnonBlank度量值,不会显示汇总,因为只返回日期列里的最大值。因为LastnonBlank是根据ACISS大小来返回最后一个,也就是返回ACISS的最大值。...第1个度量,既然知道第2参数是常数,也就是返回最大值,日历筛选的时候,因为汇总的时候是没有指定值的,所以返回为空白。 第2个度量,是在日历表上进行筛选后进行返回最后日期,所以返回的也不带有汇总。...第3个度量因为返回的是相关表,也就是原表的日期,所以返回的时候也就有了汇总一栏。 如果觉得有帮助,那麻烦您进行转发,让更多的人能够提高自身的工作效率。

    2K10

    技术分享 | MySQL 的 TIMESTAMP 类型字段非空和默认值属性的影响

    给这样的列分配一个 NULL 的值是允许的,并将该列设置为 current timestamp 。...对于插入的行,如果没有为该列指定明确的值,那么该列将被分配为 '0000-00-00 00:00:00' ,并且不会发生警告。...根据是否启用了严格的 SQL mode 或包含 NO_ZERO_DATE 的 SQL mode ,默认值 '0000-00-00 00:00:00' 可能是不被允许的。...虽然原始的建表语句中 TIMESTAMP 类型字段包含了 NULL 和 DEFAULT 属性,但是根据同步软件的错误提示,很明显,不知道什么原因,他在执行的时候忽略了这两个属性,导致真实的执行语句是:...另外,多说一点,原始语句中 createtime 和 updatetime 列都指定了默认值,但还是设置 NULL 属性,这其实就有些矛盾了,或者说是设计上的不严谨,从规范设计开发的角度,还是应该避免的

    5.1K20

    小白学习MySQL - TIMESTAMP类型字段非空和默认值属性的影响

    的库时,如果表中含有TIMESTAMP数据类型、缺省值为current_timestamp的字段,这些表的同步任务就都失败了,而另外的一些包含了DATETIME数据类型的表就同步成功了,不知道这是不是MySQL...给这样的列分配一个NULL的值是允许的,并将该列设置为current timestamp。...对于插入的行,如果没有为该列指定明确的值,那么该列将被分配为'0000-00-00 00:00:00',并且不会发生警告。...根据是否启用了严格的SQL mode或包含NO_ZERO_DATE的SQL mode,默认值'0000-00-00 00:00:00'可能是不被允许的。...另外,多说一点,原始语句中createtime和updatetime列都指定了默认值,但还是设置NULL属性,这其实就有些矛盾了,或者说是设计上的不严谨,从规范设计开发的角度,还是应该避免的, create

    4.7K40

    mysql的空值与NULL的区别

    陷阱一:空值不一定为空   空值是一个比较特殊的字段。在MySQL数据库中,在不同的情形下,空值往往代表不同的含义。这是MySQL数据库的一种特性。如在普通的字段中(字符型的数据),空值就是表示空值。...但是如果将一个空值的数据插入到TimesTamp类型的字段中,空值就不一定为空。此时为出现什么情况呢   我先创建了一个表。...其实这就是在MySQL数据库中执行SQL语句时经常会遇到的一个陷阱:空值不一定为空。在操作时,明明插入的是一个空值的数据,但是最后查询得到的却不是一个空值。   ...如果往这个数据类型的列中插入Null值,则其代表的就是系统的当前时间。另外一个是具有auto_increment属性的列。如果往这属性的列中插入Null值的话,则系统会插入一个正整数序列。...而如果在其他数据类型中,如字符型数据的列中插入Null的数据,则其插入的就是一个空值。   陷阱二:空值不一定等于空字符   在MySQL中,空值(Null)与空字符(’’)相同吗?

    3.7K70

    通过cycler实现属性的自动映射

    在matplotlib中,默认存在一个颜色 的自动映射机制,当我们绘制多条直线时,会通过这个颜色映射机制来为每条直线赋予不同的颜色,代码如下 >>> import matplotlib.pyplot as...其实是通过axes.prop_cycle这个属性,该属性用于设置一些基本的属性映射,默认情况下,设置了颜色的自动映射 >>> import matplotlib >>> matplotlib.rcParams...ff7f0e', '#2ca02c', '#d62728', '#9467bd', '#8c564b', '#e377c2', '#7f7f7f', '#bcbd22', '#17becf']) 可以看到,默认的映射属性为颜色...其实,该循环可以定义的属性很多,颜色,线条宽度,线条样式等常用属性都可以进行定义,而且不同的循环还可以进行叠加,代码如下 >>> from cycler import cycler >>> custom_cycler...通过cycler为相同元素添加属性的自动映射,极大提高了绘图效率。

    65250

    使用Optioanl优雅的处理空值

    除了以上这种”弱提示”的方式,还有一种方式是,返回值是有可能为空的。那要怎么办呢?...空集合返回值 : 如果有集合这样返回值时,除非真的有说服自己的理由,否则,一定要返回空集合,而不是null Optional: 如果你的代码是jdk8,就引入它!...当然对于实际操作来讲,返回如果Person为空,将返回null,但是PersonDTO是不能返回null的(尤其Rest接口返回的这种DTO)。...,如果当Person为空的时候,则返回一些get*的默认行为....那就要考虑,是否是调用的接口,设计的是否合理 getter中的使用 对于一个java bean,所有的属性都有可能返回null,那是否需要改写所有的getter成为Optional类型呢?

    1.9K20

    null或空值的判断处理

    name.equals("")) {      //do something } 我们来解说一下: 上述错误用法1是初学者最容易犯,也最不容易被发现的错误,因为它们的语法本身没问题,Java编译器编译时不报错...但这种条件可能在运行时导致程序出现bug,永远也不会为true,也就是时说,if块里的语句永远也不会被执行。 上述用法二,用法三 的写法,是包括很多Java熟手也很容易犯的错误,为什么是错误的呢?...对,它们的写法本身没错,但是,少了一个null判断的条件,试想,如果name=null的情况下,会发生什么后果呢?...后果是,你的程序将抛出NullPointerException异常,系统将被挂起,不再提供正常服务。 当然,如果之前已经对name作了null判断的情况例外。 正确的写法应该先加上name !...= null的条件,如例: if (name != null && !name.equals("")) {      //do something } 或者 if (!"".

    3.4K30

    null或空值的判断处理

    name.equals("")) {      //do something } 我们来解说一下: 上述错误用法1是初学者最容易犯,也最不容易被发现的错误,因为它们的语法本身没问题,Java...但这种条件可能在运行时导致程序出现bug,永远也不会为true,也就是时说,if块里的语句永远也不会被执行。 上述用法二,用法三 的写法,是包括很多Java熟手也很容易犯的错误,为什么是错误的呢?...对,它们的写法本身没错,但是,少了一个null判断的条件,试想,如果name=null的情况下,会发生什么后果呢?...后果是,你的程序将抛出NullPointerException异常,系统将被挂起,不再提供正常服务。 当然,如果之前已经对name作了null判断的情况例外。 正确的写法应该先加上name !...= null的条件,如例: if (name != null && !name.equals("")) {      //do something } 或者 if (!"".

    3.6K90

    null或空值的判断处理

    name.equals("")) {      //do something } 我们来解说一下: 上述错误用法1是初学者最容易犯,也最不容易被发现的错误,因为它们的语法本身没问题,Java编译器编译时不报错...但这种条件可能在运行时导致程序出现bug,永远也不会为true,也就是时说,if块里的语句永远也不会被执行。 上述用法二,用法三 的写法,是包括很多Java熟手也很容易犯的错误,为什么是错误的呢?...对,它们的写法本身没错,但是,少了一个null判断的条件,试想,如果name=null的情况下,会发生什么后果呢?...后果是,你的程序将抛出NullPointerException异常,系统将被挂起,不再提供正常服务。 当然,如果之前已经对name作了null判断的情况例外。 正确的写法应该先加上name !...= null的条件,如例: if (name != null && !name.equals("")) {      //do something } 或者 if (!"".

    3.1K100
    领券