Springboot + MySQL+ JPA II save方法详解

JPA没有专门的update接口,save接口同时支持update操作

一、save(单条添加)

Service层中添加save方法(save是三方件自带接口不需要再dao层中添加)

@Transactional
public User save(User user){
	return userDao.save(user);
}

control层

/**
 * 单条数据保存
 * @param id 自增的,可以不填
 * @param name
 * @param age
 * @return
 */
@GetMapping("/save")
public User save(Integer id,String name, Integer age){
	User user = new User();
	user.setId(id);
	user.setName(name);
	user.setAge(age);
	return userService.save(user);
}

测试成功!(id是主键自增的,可以不填)

 二、saveAll(批量添加)

 Service层中添加save方法(save是三方件自带接口不需要再dao层中添加)

@Transactional
public <S extends User> List<S> saveAll(Iterable<S> entities) {
	return userDao.saveAll(entities);
}

 control层

/**
 * 批量保存数据
 * @param names
 * @param ages
 * @return
 */
@GetMapping("/saveAll")
public List<User> saveAll(String[] names,Integer[] ages){
	List<User> list = new ArrayList<>();
	for(int i=0;i<names.length;i++){
		User user = new User();
		user.setName(names[i]);
		user.setAge(ages[i]);
		list.add(user);
	}
	return userService.saveAll(list);
}

测试成功!(id是主键自增的,可以不填)

 

最后小结:

传入参数中有id:

         判断id是否存在:

                a)如果id存在,则进行update操作

                b)如果id不存在,则新加的数据id为最后一个id+1(不管你写的id是多少)

                例:数据库中最后一个id为10,你加的id是20,最后加入数据库的id还是11(不是20)

传入参数没有id:

        直接在数据库中最后添加数据,id为最后数据的id+1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

若博豆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值