本文实例讲述了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 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