mybatisplus的ServiceImpl提供的两个lambda方法,lambdaQuery()和lambdaUpdate()

lambdaQuery()lambdaUpdate().这两个方法相比LambdaQueryWrapperLambdaUpdateWrapper的好处是可以直接.list获.one,当然他们的功能是差不多的。主要用于构造sql语句的where条件的。
1.lambdaQuery()的使用方法
lambdaQuery()返回的是一个Wrapper对象
对于复杂条件的查询,使用lambdaUpdate()进行构建查询。简单的直接用ServiceImpl的get方法就行了。

//select * from tb_user WHERE (username LIKE ? AND status = ? AND balance >= ? AND balance <= ?)
        List<User> list = lambdaQuery()
                .like(name != null, User::getUsername, name)
                .eq(status != null, User::getStatus, status)
                .ge(minBalance != null, User::getBalance, minBalance)
                .le(maxBalance != null, User::getBalance, maxBalance)
                .list();

2.lambdaUpdate()的使用方法
对于复杂条件的更新,使用lambdaUpdate()进行构建更新。简单的直接用ServiceImpl的update方法就行了。

@Override
@Transactional
public void deductBalance(Long id, Integer money) {
    // 1.查询用户
    User user = getById(id);
    // 2.校验用户状态
    if (user == null || user.getStatus() == 2) {
        throw new RuntimeException("用户状态异常!");
    }
    // 3.校验余额是否充足
    if (user.getBalance() < money) {
        throw new RuntimeException("用户余额不足!");
    }
    // 4.扣减余额 update tb_user set balance = balance - ? , status = ? where(id = ?, balance = ?)
    int remainBalance = user.getBalance() - money;
    lambdaUpdate()
            .set(User::getBalance, remainBalance) // 更新余额
            .set(remainBalance == 0, User::getStatus, 2) // 动态判断,是否更新status
            .eq(User::getId, id)
            .eq(User::getBalance, user.getBalance()) // 乐观锁
            .update();
}
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MybatisPlus ServiceImpl是一个基于MybatisPlus框架的服务实现类,用于实现业务逻辑和数据访问操作。它提供了一系列的方法,如增删改查等,可以方便地操作数据库。同时,它还支持事务管理、分页查询等功能,使得开发人员可以更加高效地开发和维护代码。 ### 回答2: Mybatis Plus是一款基于Mybatis框架的增强工具,它提供了很多方便的功能来简化我们在使用Mybatis时的开发工作。ServiceImplMybatis Plus中的一个类,它是一个服务类的实现类,用于实现我们自定义的Service接口中定义的方法。 在Mybatis Plus中,我们可以使用ServiceImpl来实现自己的Service接口,这样就可以实现Service接口中定义的方法ServiceImpl提供了一些常用的方法,例如增删改查等操作,我们可以直接调用这些方法来进行数据库操作。 在编写ServiceImpl时,我们首先要继承Mybatis Plus提供ServiceImpl类,然后实现我们自定义的Service接口。在实现Service接口的方法时,我们可以利用ServiceImpl提供方法来实现对数据库的操作。 例如,我们可以使用ServiceImpl中的save方法来保存一个对象到数据库中,使用ServiceImpl中的update方法来更新数据库中的数据,使用ServiceImpl中的removeById方法来删除数据库中的数据等等。这些方法都是Mybatis Plus提供的,我们可以直接调用这些方法来实现相应的功能。 除了提供了一些常用的方法之外,ServiceImpl还可以进行一些其他配置,例如设置分页查询的参数,设置数据库事务的处理方式等等。 总之,Mybatis Plus的ServiceImpl是一个方便且强大的工具,可以帮助我们简化开发工作,提高开发效率。通过继承ServiceImpl并实现自定义的Service接口,我们可以轻松地实现数据库操作,减少了很多重复性的代码。 ### 回答3: MyBatis Plus是一个在MyBatis基础上进行扩展的持久化框架,它简化了MyBatis的使用,提供了更加便捷的方法和功能。 Service层是业务逻辑的处理层,负责处理业务逻辑、调用Dao层的方法,并对数据进行处理和处理结果进行封装。 ServiceImplService层的实现类,它实现了Service接口中定义的方法,并对具体的业务逻辑进行了实现。在MyBatis Plus中,通常使用ServiceImpl进行数据库的访问和操作。 MyBatis Plus的ServiceImpl提供了很多方便的方法,例如:根据条件查询、分页查询、插入、更新和删除等。这些方法可以直接在ServiceImpl中调用,无需编写SQL语句。 在ServiceImpl中,一般会注入对应的Mapper接口,并通过调用Mapper接口中的方法来进行数据库的操作。在使用MyBatis Plus时,Mapper接口直接继承自BaseMapper接口,无需再编写XML文件。 在ServiceImpl中,还可以使用自定义的方法来进行更加复杂的业务逻辑操作,例如:多表查询和关联操作等。这些方法可以在ServiceImpl中自己实现,或者调用其他Service层或Dao层的方法。 总之,MyBatis Plus的ServiceImpl提供了很多便捷的方法和功能,可以简化开发人员的工作,提高开发效率。它是开发中不可或缺的一部分,能够帮助我们更好地进行数据库的操作和业务逻辑的处理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值