Hibernate实现批量添加数据的方法

本文实例讲述了Hibernate实现批量添加数据的方法。分享给大家供大家参考,具体如下:

1.Hibernate_016_BatchAddData程序目录结构:

2.lib目录下所引入的jar包:

3.MedicineDao.java源代码:

package com.xqh.dao;
import java.util.List;
import org.hibernate.Session;
import com.xqh.model.Medicine;
import com.xqh.util.HibernateUtil;
/**
 * 药品数据库操作类
 *
 */
public class MedicineDao {
  /**
   * 批量保存药品
   *
   * @param ms
   *      List集合
   */
  public void saveMedicines(List<Medicine> ms) {
    Session session = null;
    if (ms != null && ms.size() > 0) {
      try {
        session = HibernateUtil.getSession(); // 获取Session
        session.beginTransaction(); // 开启事物
        Medicine medicine = null; // 创建药品对象
        // 循环获取药品对象
        for (int i = 0; i < ms.size(); i++) {
          medicine = (Medicine) ms.get(i); // 获取药品
          session.save(medicine); // 保存药品对象
          // 批插入的对象立即写入数据库并释放内存
          if (i % 10 == 0) {
            session.flush();
            session.clear();
          }
        }
        session.getTransaction().commit(); // 提交事物
      } catch (Exception e) {
        e.printStackTrace(); // 打印错误信息
        session.getTransaction().rollback(); // 出错将回滚事物
      } finally {
        HibernateUtil.closeSession(session); // 关闭Session
      }
    }
  }
}

4.Medicine.java源代码:

package com.xqh.model;
/**
 * 药品持久化类
 */
public class Medicine {
  private Integer id;       //id号
  private String name;      //药品名称
  private double price;      //价格
  private String factoryAdd;   //出厂地址
  public Integer getId() {
    return id;
  }
  public void setId(Integer id) {
    this.id = id;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public double getPrice() {
    return price;
  }
  public void setPrice(double price) {
    this.price = price;
  }
  public String getFactoryAdd() {
    return factoryAdd;
  }
  public void setFactoryAdd(String factoryAdd) {
    this.factoryAdd = factoryAdd;
  }
}

5.Medicine.hbm.xml源代码:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
  "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
  <class name="com.xqh.model.Medicine" table="tb_medicine_batch">
    <id name="id">
      <generator class="native"/>
    </id>
    <property name="name" not-null="true" length="200" />
    <property name="price" not-null="true"/>
    <property name="factoryAdd" length="200"/>
  </class>
</hibernate-mapping>

6.SaveMedicine.java源代码:

package com.xqh.servlet;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.xqh.dao.MedicineDao;
import com.xqh.model.Medicine;
public class SaveMedicine extends HttpServlet {
  private static final long serialVersionUID = 3743334039515411666L;
  public void doPost(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    // 药品名称
    String names[] = request.getParameterValues("name");
    // 价格
    String prices[] = request.getParameterValues("price");
    // 出厂地址
    String adds[] = request.getParameterValues("factoryAdd");
    // 有效性判断
    if(names != null && prices != null && adds != null){
      if(names.length == prices.length && names.length == adds.length){
        // 实例化一个List集合
        List<Medicine> ms = new ArrayList<Medicine>();
        Medicine m = null; // 药品对象
        // 依次实例化药品对象并添加到集合中
        for (int i = 0; i < names.length; i++) {
          m = new Medicine(); // 实例化药品
          // 对属性赋值
          m.setName(names[i]);
          m.setPrice(Double.parseDouble(prices[i]));
          m.setFactoryAdd(adds[i]);
          ms.add(m); // 添加到集合中
        }
        // 实例化MedicineDao对象
        MedicineDao dao = new MedicineDao();
        dao.saveMedicines(ms); // 批量保存药品
        request.setAttribute("info", "药品信息保存成功!!!");
      }
    }
    // 转发到result.jsp页面
    request.getRequestDispatcher("result.jsp").forward(request, response);
  }
}

7.CharacterEncodingFilter.java源代码:

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package com.xqh.util;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
/**
 * 字符编码过滤器
 */
public class CharacterEncodingFilter implements Filter{
  protected String encoding = null;
  protected FilterConfig filterConfig = null;
  public void init(FilterConfig filterConfig) throws ServletException {
    this.filterConfig = filterConfig;
    this.encoding = filterConfig.getInitParameter("encoding");
  }
  public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
    if (encoding != null) {
      request.setCharacterEncoding(encoding);
      response.setContentType("text/html; charset="+encoding);
    }
    chain.doFilter(request, response);
  }
  public void destroy() {
    this.encoding = null;
    this.filterConfig = null;
  }
}

8.HibernateUtil.java源代码:

package com.xqh.util;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
/**
 * Hibernate初始化类,用于获取Session、SessionFactory 及关闭Session
 */
public class HibernateUtil {
  // SessionFactory对象
  private static SessionFactory factory = null;
  // 静态块
  static {
    try {
      // 加载Hibernate配置文件
      Configuration cfg = new Configuration().configure();
      // 实例化SessionFactory
      factory = cfg.buildSessionFactory();
    } catch (HibernateException e) {
      e.printStackTrace();
    }
  }
  /**
   * 获取Session对象
   * @return Session对象
   */
  public static Session getSession() {
    //如果SessionFacroty不为空,则开启Session
    Session session = (factory != null) ? factory.openSession() : null;
    return session;
  }
  /**
   * 获取SessionFactory对象
   * @return SessionFactory对象
   */
  public static SessionFactory getSessionFactory() {
    return factory;
  }
  /**
   * 关闭Session
   * @param session对象
   */
  public static void closeSession(Session session) {
    if (session != null) {
      if (session.isOpen()) {
        session.close(); // 关闭Session
      }
    }
  }
}

9.hibernate.cfg.xml源代码:

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
     "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
     "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
  <session-factory>
    <!-- 方言 -->
    <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
    <!-- 数据库连接 -->
    <property name="connection.url">jdbc:mysql://localhost:3306/learn</property>
    <!-- 数据库连接用户名 -->
    <property name="connection.username">root</property>
    <!-- 数据库连接密码 -->
    <property name="connection.password">1120</property>
    <!-- 数据库驱动 -->
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    <!-- 打印SQL语句 -->
    <property name="show_sql">true</property>
    <!-- 自动建表 -->
    <property name="hibernate.hbm2ddl.auto">update</property>
    <!-- 映射文件 -->
    <mapping resource="com/xqh/model/Medicine.hbm.xml"/>
  </session-factory>
</hibernate-configuration>

10.log4j.properties源代码:

### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
### direct messages to file hibernate.log ###
#log4j.appender.file=org.apache.log4j.FileAppender
#log4j.appender.file.File=hibernate.log
#log4j.appender.file.layout=org.apache.log4j.PatternLayout
#log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
### set log levels - for more verbose logging change 'info' to 'debug' ###
log4j.rootLogger=warn, stdout
#log4j.logger.org.hibernate=info
#log4j.logger.org.hibernate=debug
### log HQL query parser activity
#log4j.logger.org.hibernate.hql.ast.AST=debug
### log just the SQL
#log4j.logger.org.hibernate.SQL=debug
### log JDBC bind parameters ###
#log4j.logger.org.hibernate.type=info
#log4j.logger.org.hibernate.type=debug
### log schema export/update ###
#log4j.logger.org.hibernate.tool.hbm2ddl=debug
### log HQL parse trees
#log4j.logger.org.hibernate.hql=debug
### log cache activity ###
#log4j.logger.org.hibernate.cache=debug
### log transaction activity
#log4j.logger.org.hibernate.transaction=debug
### log JDBC resource acquisition
#log4j.logger.org.hibernate.jdbc=debug
### enable the following line if you want to track down connection ###
### leakages when using DriverManagerConnectionProvider ###
#log4j.logger.org.hibernate.connection.DriverManagerConnectionProvider=trace

11.index.jsp源代码:

<%@ page language="java" contentType="text/html" pageEncoding="GBK"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>批量添加药品信息</title>
    <style type="text/css">
td {
  background: #EBEBEB;
  font-family: Verdana;
  font-size: 12px;
  background-color: #EBEBEB;
  color: black;
  line-height: 20px;
  height: 30px;
}
</style>
    <script type="text/javascript">
    function add(){
      var a = document.getElementById("a");
      var b = document.getElementById("b");
      b.innerHTML += a.innerHTML;
    }
    function reduce() {
      var a = document.getElementById("a");
      var b = document.getElementById("b");
      var stra = a.innerHTML;
      var strb = b.innerHTML;
      b.innerHTML = strb.substring(0, strb.length - stra.length);
    }
    function save(formName){
      for(i=0;i<formName.length;i++){
        if(formName.elements[i].value==""){
          alert("请填写完整信息!");
          return false;
        }
      }
    }
  </script>
  </head>
  <body onload="add()">
    <form action="SaveMedicine" method="post"
      onsubmit="return save(this);">
      <table align="center" border="0" cellpadding="3" cellspacing="1"
        width="600">
        <tr>
          <td align="center">
            <br>
            <h1>
              批量添加药品信息
            </h1>
          </td>
        </tr>
        <tr>
          <td>
            <div id="b"></div>
          </td>
        </tr>
        <tr>
          <td>
            <input type="button" value="添加一行 " onclick="add()">
            <input type="button" value="减少一行" onclick="reduce()">
            <input type="submit" value="批量添加到数据库">
          </td>
        </tr>
      </table>
    </form>
    <div id="a" style="display: none">
      <table align="center" border="0">
        <tr>
          <td>
            名称:
          </td>
          <td>
            <input type="text" name="name" size="13">
          </td>
          <td>
            单价:
          </td>
          <td>
            <input type="text" name="price" size="13">
          </td>
          <td>
            厂址:
          </td>
          <td>
            <input type="text" name="factoryAdd" size="30">
          </td>
        </tr>
      </table>
    </div>
  </body>
</html>

12.result.jsp源代码:

<%@ page language="java" contentType="text/html" pageEncoding="GBK"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <head>
  <title>结果信息</title>
  <!--
  <link rel="stylesheet" type="text/css" href="styles.css">
  -->
 </head>
 <body>
  <div align="center">
    <font color="red" size="12px;" style="font-weight: bold;">
      ${info}
    </font>
    <br><br><br><br>
    <a href="index.jsp">返回</a>
  </div>
 </body>
</html>

13.数据表tb_medicine_batch结构:

14.程序运行结果截图:

希望本文所述对大家基于Hibernate框架的Java程序设计有所帮助。

(0)

相关推荐

  • Hibernate批量处理海量数据的方法

    本文实例讲述了Hibernate批量处理海量数据的方法.分享给大家供大家参考,具体如下: Hibernate批量处理海量其实从性能上考虑,它是很不可取的,浪费了很大的内存.从它的机制上讲,Hibernate它是先把符合条件的数据查出来,放到内存当中,然后再进行操作.实际使用下来性能非常不理想,在笔者的实际使用中采用下面的第三种优化方案的数据是:100000条数据插入数据库, 需要约30分钟,呵呵,晕倒.(本人10分钟插入1000000条数据(字段比较小)) 总结下来有三种来处理以解决性能问题:

  • Hibernate+JDBC实现批量插入、更新及删除的方法详解

    本文实例讲述了Hibernate JDBC实现批量插入.更新及删除的方法.分享给大家供大家参考,具体如下: 一.批量插入(两种方式) 1. 通过Hibernate缓存 如果这样写代码进行批量插入(初始设想): package com.anlw.util; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.

  • jsp Hibernate批量更新和批量删除处理代码

    以下程序直接通过Hibernate API批量更新CUSTOMERS表中年龄大于零的所有记录的AGE字段: tx = session.beginTransaction();Iterator customers=session.find("from Customer c where c.age>0").iterator();while(customers.hasNext()){Customer customer=(Customer)customers.next();customer

  • 基于spring boot 1.5.4 集成 jpa+hibernate+jdbcTemplate(详解)

    1.pom添加依赖 <!-- spring data jpa,会注入tomcat jdbc pool/hibernate等 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <

  • Hibernate管理Session和批量操作分析

    本文详细分析了Hibernate管理Session和批量操作的用法.分享给大家供大家参考.具体分析如下: Hibernate管理Session Hibernate自身提供了三种管理Session对象的方法 ① Session对象的生命周期与本地线程绑定 ② Session对象的生命周期与JTA事务绑定 ③ Hibernate委托程序管理Session对象的生命周期 在Hibernate的配置文件中,hibernate.current_session_context_class属性用于指定Sess

  • hibernate批量操作实例详解

    本文实例讲述了hibernate批量操作的方法.分享给大家供大家参考,具体如下: Hibernate的批量处理 Hibernate完全以面向对象的方式来操作数据库,当程序里以面向对象的方式操作持久化对象时,将被自动转换为对数据库的操作.例如调用Session的delete()方法来删除持久化对象,Hibernate将负责删除对应的数据记录:当执行持久化对象的set方法时,Hibernate将自动转换为对应的update方法,修改数据库的对应记录. 问题是如果需要同时更新100 000条记录,是不

  • 解析使用jdbc,hibernate处理clob/blob字段的详解

    (1)不同数据库中对应clob,blob的类型:mysql中 : clob对应text  blob对应blobdb2/oracle中 clob对应clob blob对应blob (2)domain中对应类型:clob 对应 String   blob 对应 byte[]clob 对庆 java.sql.Clob blob 对应 java.sql.Blob (3)hibernate配置文件中对应类型:clob > clob   blob > binay 也可以直接使用数据库提供类型,例如:ora

  • Hibernate实现批量添加数据的方法

    本文实例讲述了Hibernate实现批量添加数据的方法.分享给大家供大家参考,具体如下: 1.Hibernate_016_BatchAddData程序目录结构: 2.lib目录下所引入的jar包: 3.MedicineDao.java源代码: package com.xqh.dao; import java.util.List; import org.hibernate.Session; import com.xqh.model.Medicine; import com.xqh.

  • php批量添加数据与批量更新数据的实现方法

    本文实例讲述了php批量添加数据与批量更新数据的实现方法.分享给大家供大家参考.具体分析如下: php如果要批量保存数据我们只要使用sql的insert into语句就可能实现数据批量保存了,如果是更新数据使用update set就可以完成更新了,操作方法都非常的简单,下面整理两个例子. 批量数据录入 设计方法:同时提交多条表单记录,为每一条记录设置相同的文本域名称,然后在表单处理页中,通过for循环来读取提取表单提交的数据,最后以数据的形式将数据逐条添加到数据库中. 其中,应用一个count(

  • Yii2如何批量添加数据

    批量添加这个操作,在实际开发中经常用得到,今天小编抽空给大家整理些有关yii2批量添加的问题,感兴趣的朋友一起看看吧. 在上篇文章给大家介绍了关于浅析Yii2 gridview实现批量删除教程,当然,着重点在于怎么去操作gridview了,今儿我们来好好谈谈yii2如何批量添加数据? 有同学嚷嚷了,这还不简单,我foreach一循环,每个循环里面直接把数据插入到数据库,简单粗暴完事!我擦嘞,哥,你要是跟我在一个公司,我觉得第二天见到你的概率可就不大了! 话不多说,说多了你在骂我,我们步入正题,先

  • ThinkPHP3.2框架使用addAll()批量插入数据的方法

    本文实例讲述了ThinkPHP3.2框架使用addAll()批量插入数据的方法.分享给大家供大家参考,具体如下: thinkphp中model类的addAll()方法可以将数据同时添加到数据库中. // 批量添加数据 (only MySQL) $user = M('user'); //array('表字段'=>'值') $dataList[] = array('name'=>'thinkphp','email'=>'thinkphp@gamil.com'); $dataList[] =

  • mybatis使用oracle进行添加数据的方法

    本次博主主要进行oralce数据库开发,好久不用oracle,有很多知识点也忘的差不多了,本次主要是复习一下工作中主要使用的一些sql语句编写: 查询 查询语句都是正常的,但是需要注意的是oracle数据库在查询的时候,表名使用别名的时候,请不要使用as关键字,只有mysql数据库才可以使用,oracle只支持字段名别名可以使用as关键字. 增加 添加数据的时候,我们后台很可能使用到添加后的主键id,此时也跟mysql不一样,mybatis只要配置一下insert属性就可以了,比如: <inse

  • Thinkphp批量更新数据的方法汇总

    以下小编给大家列出了三种实现thinkphp批量更新数据的方法,写的不好还请见谅,有意见欢迎提出,共同学习进步! 方法一: //批量修改 data二维数组 field关键字段 参考ci 批量修改函数 传参方式 function batch_update($table_name='',$data=array(),$field=''){ if(!$table_name||!$data||!$field){ return false; }else{ $sql='UPDATE '.$table_name

  • YII框架批量插入数据的方法

    本文实例讲述了YII框架批量插入数据的方法.分享给大家供大家参考,具体如下: public function insertSeveral($table, $array_columns) { $sql = ''; $params = array(); $i = 0; foreach ($array_columns as $columns) { $names = array(); $placeholders = array(); foreach ($columns as $name => $valu

  • php使用mysqli向数据库添加数据的方法

    本文实例讲述了php使用mysqli向数据库添加数据的方法.分享给大家供大家参考.具体实现方法如下: $mydb = new mysqli('localhost', 'username', 'password', 'databasename'); $sql = "INSERT INTO users (fname, lname, comments) VALUES ('$_POST[fname]', '$_POST[lname]', '$_POST[comments]')"; if ($m

  • sql下三种批量插入数据的方法

    本文将介绍三种批量插入数据的方法.第一种方法是使用循环语句逐个将数据项插入到数据库中:第二种方法使用的是SqlBulkCopy,使您可以用其他源的数据有效批量加载 SQL Server 表:第三种使用的方法是sql server中的表值参数方法,表值参数是 SQL Server 2008 中的新参数类型.表值参数是使用用户定义的表类型来声明的.使用表值参数,可以不必创建临时表或许多参数,即可向 Transact-SQL 语句或例程(如存储过程或函数)发送多行数据. 代码示例: 此例子为控制台输出

  • php实现refresh刷新页面批量导入数据的方法

    本文实例讲述了php实现refresh刷新页面批量导入数据的方法.分享给大家供大家参考.具体分析如下: 这个功能是参考dedecms生成html页面的原理,只是dedecms使用的是js跳转而我使用的是refresh进行跳转,效果是一样的,下面我们一起来看一个php实现批量导入数据的方法. 因为我有1000W数据一次导入数据库肯定是不可行了,所以我就导致了每一次导入50条或更多数据,然后下次再刷新一次这样就可以解决这个问题了,代码如下: 复制代码 代码如下: <?php set_time_lim

随机推荐