JPA 执行单条和多条Insert插入语句(MySQL、Oracle)

1 执行单条Insert语句

1.1 MySQL

由于executeUpdate()语句只能执行一行语句,可以使用insert into tablename(...) values(...),(...)格式将多行insert into语句变为一行。

public class Test{
    @PersistenceContext
    private EntityManager entityManager;
     public insert() {
        String insertSql="insert into test(id) values('1'),('2');"
        Query query = this.entityManager.createNativeQuery(insertSql);
        query.executeUpdate();
    }
}

 1.2 Oracle

由于executeUpdate()语句只能执行一行语句,可以使用insert all into tablename(...) values(...)  tablename(...) values(...) select 1 from DUAL;

格式将多行insert into语句变为一行。

public class Test{
    @PersistenceContext
    private EntityManager entityManager;
     public insert() {
        String insertSql="insert all into test(id) values('1') into test(id) values('2') select 1 from DUAL;"
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JPA是Java Persistence API的缩写,它是一种用于持久化数据的Java规范。要保存多条数据,可以使用JPA的EntityManager来完成。 首先,我们需要创建一个实体类来映射我们要保存的数据。这个实体类需要使用@Entity注解来标记,并定义对应的属性和表结构。例如,我们可以创建一个实体类User,它包含id、name、age等属性。 接下来,我们可以使用EntityManager的persist方法来保存多条数据。首先,我们需要获取一个EntityManager对象,可以通过注入或者创建EntityManagerFactory来获得。然后,我们可以使用EntityManager的beginTransaction方法开启一个事务。 在事务中,我们可以通过实例化多个User对象,并设置它们的属性。然后,我们可以使用EntityManager的persist方法来保存这些User对象。在调用persist方法后,实体对象会被标记为持久化状态,但实际的数据库操作会在事务提交时才执行。 最后,我们可以使用事务的commit方法来提交事务。在事务提交后,保存的多条数据会被写入数据库。 以下是一个保存多条User数据的示例代码: ```java EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory("yourPersistenceUnitName"); EntityManager entityManager = entityManagerFactory.createEntityManager(); entityManager.getTransaction().begin(); User user1 = new User(); user1.setName("张三"); user1.setAge(20); entityManager.persist(user1); User user2 = new User(); user2.setName("李四"); user2.setAge(25); entityManager.persist(user2); entityManager.getTransaction().commit(); entityManager.close(); entityManagerFactory.close(); ``` 以上是使用JPA保存多条数据的简单步骤。通过使用EntityManager的persist方法和事务的commit方法,我们可以很方便地保存多条数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值