Hibernate SQL优化小技巧使用dynamic-insert="true" insert="true"

================testSaveUser================= Hibernate: insert into Users (age, firstname, lastname) values (?, ?, ?) ================testUpdateUser================= Hibernate: insert into Users (age, firstname, lastname) values (?, ?, ?) Hibernate: update Users set age=?, firstname=?, lastname=? where ID=?
如果我们在<class ...>中加上 dynamic-insert="true" dynamic-update="true",变成如下。
<class name="model.User" table="Users" dynamic-insert="true" dynamic-update="true">
再次运行测试类,就会发现生成的SQL中涉及的字段只包含User类中修改的属性所对应的表字段。
================testSaveUser================= Hibernate: insert into Users (age) values (?) ================testUpdateUser================= Hibernate: insert into Users (age) values (?) Hibernate: update Users set firstname=? where ID=?
如果一个表的结构很复杂,字段很多的情况下,使用dynamic-insert,dynamic-update能够性能上的少许提升。

================好玩的分隔线=================

Hibernate允许我们在映射文件里控制insert和update语句的内容.比如在映射文件中<property 元素中的update属性设置成为false,那么这个字段,将不被包括在基本的update语句中,修改的时候,将不包括这个字段了.insert同理.dynamic动态SQL语句的配置也是很常用的.下面介绍配置SQL语句的具体属性:       1)<property>元素 insert属性:设置为false,在insert语句中不包含这个字段,表示永远不会被插入,默认true       2)<property>元素 update属性:设置为false,在update语句中不包含这个字段,表示永远不会被修改,默认true       3)<class>元素 mutable属性:设置为false就是把所有的<property>元素的update属性设置为了false,说明这个对象不会被更新,默认true       4)<property>元素 dynamic-insert属性:设置为true,表示insert对象的时候,生成动态的insert语句,如果这个字段的值是null就不会加入到insert语句当中.默认false       5)<property>元素 dynamic-update属性,设置为true,表示update对象的时候,生成动态的update语句,如果这个字段的值是null就不会被加入到update语句中,默认false       6)<class>元素 dynamic-insert属性:设置为true,表示把所有的<property>元素的dynamic-insert属性设置为true,默认false       7)<class>元素 dynamic-update属性:设置为true,表示把所有的<property>元素的dynamic-update属性设置为true,默认false

      Hibernate生成动态SQL语句的消耗的系统资源(比如CPU,内存等)是很小的,所以不会影响到系统的性能,如果表中包含N多字段,建议把dynamic-update属性和insert属性设置为true,这样在插入和修改数据的时候,语句中只包括要插入或者修改的字段.可以节省SQL语句的执行时间,提高程序的运行效率.

转载于:https://www.cnblogs.com/xigua1hao/p/Hibernate.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: "spring.jpa.hibernate.ddl-auto=update" 指的是在启动应用时,自动更新数据库表结构。它会扫描指定的包,如果发现实体类中定义的表结构与数据库中的表不一致,就会自动更新数据库表。 ### 回答2: 在Spring框架中,我们可以使用配置属性`spring.jpa.hibernate.ddl-auto=update`来指定应用程序在启动时如何处理数据库的结构变化。`ddl-auto`是一个指示Hibernate如何管理数据库模式转换的属性。当设置为`update`时,Hibernate会检测实体类的变化,并根据这些变化来更新数据库的模式。 对于这个配置属性的使用,我们还需要指定需要扫描的包,以便Hibernate能够找到实体类并进行数据库模式的更新。通常,我们将实体类放在指定的包中,并在应用程序启动时,Hibernate会自动扫描这些包以找到所有的实体类。 例如,我们可以在配置文件中添加以下配置: ``` spring.jpa.hibernate.ddl-auto=update spring.jpa.hibernate.packagesToScan=com.example.entity ``` 在这个例子中,我们指定了需要扫描的包为`com.example.entity`。Hibernate将会在这个包以及其子包中查找所有的实体类,并根据数据库的当前状态来更新模式。如果有新的实体类添加到了这个包中,Hibernate将会自动创建相应的表。如果已存在的实体类发生了变化(例如,增加了新的字段或删除了某些字段),Hibernate会对表结构进行更新,以反映这些变化。 使用`spring.jpa.hibernate.ddl-auto=update`配置属性配合指定需要扫描的包,可以方便地实现数据库模式的自动更新。但需要注意的是,在生产环境中,建议将这个属性设置为`none`,以免意外地修改或删除数据库的表结构。 ### 回答3: 指定需要扫描的包是使用Spring框架中的JPA和Hibernate作为持久化方案时的配置项。在配置文件中使用spring.jpa.hibernate.ddl-auto=update可以告诉Hibernate根据实体类来自动更新数据库的表结构。 首先,需要在配置文件中指定这个属性,它可以有以下几个取值: - create:每次启动时都会创建新的表,如果表已经存在,则会先删除再创建。 - update:每次启动时都会更新数据库的表结构,如果实体类中有新增的字段,则会自动添加到表中。 - create-drop:每次启动时都会创建新的表,但是在关闭应用程序时会删除表。 - validate:每次启动时会校验实体类和数据库表的结构是否一致,如果不一致则会抛出异常。 其次,指定需要扫描的包是为了告诉Hibernate在哪些包下面去找实体类。一般情况下,我们会将实体类放在一个特定的包中,如com.example.entity,这时可以设置以下配置项来指定需要扫描的包: - spring.jpa.hibernate.ddl-auto=update - spring.jpa.hibernate.ddl-auto=update;spring.jpa.hibernate.packageToScan=com.example.entity 总结来说,spring.jpa.hibernate.ddl-auto=update指定了Hibernate在启动时自动更新数据库表结构的配置项,而指定需要扫描的包是为了告诉Hibernate在哪些包下面去寻找实体类。这样就可以根据实体类的变化自动生成或更新数据库的表结构,方便开发和维护数据库。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值