springboot中@update使用

@update使用的两种情况

1.第一种情况

update操作传递一个参数

@Update(“update user set sex = “男” where id=#{id}”)
public int update(int id);

这种情况只有一个参数,参数id可以不用使用@param

2.第二种情况

update操作传递两个及以上参数

@Update(“update user set name =#{name} where id=#{id}”)
public int update(@Param(“id”) int id,@Param(“name”) String name);

这种情况有两个参数,需要使用@Param进行对两个参数进行区分,否则,在操作数据表时会报sql语句有注入风险。

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Spring Boot使用@Transactional注解需要在启动类上添加@EnableTransactionManagement注解。事务管理是应用系统开发不可或缺的一部分,Spring为事务管理提供了丰富的功能支持。在Spring项目,默认情况下,@Transactional注解会回滚运行时异常及其子类,而其他范围之外的异常不会被Spring回滚数据。如果我们也想要回滚其他异常,可以在方法或类上加上@Transactional(rollbackFor = Exception.class)注解。 Spring本身没有事务,只有数据库才有事务。Spring的事务是通过AOP和动态代理实现的。在我们操作数据库时,实际上是通过动态代理进行功能扩展。在代码操作数据库之前,Spring会通过数据库客户端打开数据库事务。如果代码执行完毕没有异常信息或者没有Spring要捕获的异常信息,Spring会通过数据库客户端提交事务。如果有异常信息或者有Spring要捕获的异常信息,Spring会通过数据库客户端程序回滚事务,从而控制数据库事务。 以下是一些使用@Transactional注解的代码示例: ```java @Service public class UserService { @Autowired private UserRepository userRepository; @Transactional public void createUser(User user) { userRepository.save(user); } @Transactional(rollbackFor = Exception.class) public void updateUser(User user) { userRepository.save(user); } @Transactional(propagation = Propagation.REQUIRED) public void deleteUser(Long userId) { userRepository.deleteById(userId); } } ``` 在上面的代码示例,@Transactional注解应用于方法上,表示这些方法会在数据库事务运行。createUser方法和updateUser方法使用了默认的事务回滚策略,即回滚运行时异常及其子类。deleteUser方法使用了REQUIRED传播行为,表示如果当前没有事务,则创建一个新的事务;如果当前已经存在事务,则加入到当前事务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot @Transactional 的使用细节](https://blog.csdn.net/Yue_zuozuo/article/details/84823490)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【Java 基础】SpringBoot @Transactional 注解的使用与实践](https://blog.csdn.net/yuxiangdeming/article/details/125243814)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值