hibernate mysql 多线程_如何使用Hibernate JPA线程安全进行数据库访问?

我想知道我需要做什么才能访问数据库线程安全。

这是我的Entity类:

@Entity

@Table(name = "students")

@NamedQuery(name = "Student.getAll", query = "SELECT s FROM Student s")

public class Student {

@Id

@GeneratedValue(strategy = GenerationType.AUTO)

private long id;

@Column(length = 32, name = "name")

private String name;

// ... constructor, getters and setters, toString ...

}

这是DbService类:

public class DbService {

public EntityManager em = Persistence

.createEntityManagerFactory("MyPersistenceUnit")

.createEntityManager();

public Student add(Student student) {

EntityTransaction tx = em.getTransaction();

tx.begin();

Student studentFromDb = em.merge(student);

tx.commit();

return studentFromDb;

}

public void delete(long id) {

EntityTransaction tx = em.getTransaction();

tx.begin();

em.remove(get(id));

tx.commit();

}

public Student get(long id) {

return em.find(Student.class, id);

}

public void update(Student student) {

EntityTransaction tx = em.getTransaction();

tx.begin();

em.merge(student);

tx.commit();

}

public List getAll() {

TypedQuery namedQuery =

em.createNamedQuery("Student.getAll", Student.class);

return namedQuery.getResultList();

}

}

这是与DbService一起使用的类:

public class SomeDbWorker implements Runnable {

@Override

public void run() {

DbService service = new DbService();

// do something ...

service.add( ... );

service.delete( ... );

service.getAll();

// ...

}

}

使 add() , delete() , update() 和 getAll() 方法同步是否足够?

是否可以像在源代码中那样创建DbService的多个实例?还是只需要创建一个实例?

也许我应该使用单例设计模式?还是使DbService静态所有方法?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值