学无先后,达者为师

网站首页 编程语言 正文

QueryWrapper、LambdaQueryWrapper、QueryChainWrapper、LambdaQueryChainWrapper比较

作者:一勺菠萝丶 更新时间: 2024-02-01 编程语言

QueryWrapper

QueryWrapper<OrderEntity> queryWrapper = new QueryWrapper<OrderEntity>().select("id","order_msg").eq("order_msg","571");
orderMapper.selectOne(queryWrapper); // SELECT id,order_msg FROM my_mysql.order WHERE (order_msg = '571')

LambdaQueryWrapper

LambdaQueryWrapper<OrderEntity> lambdaQueryWrapper = new LambdaQueryWrapper<OrderEntity>().select(OrderEntity::getId, OrderEntity::getOrderMsg).eq(OrderEntity::getOrderMsg,"572");
orderMapper.selectOne(lambdaQueryWrapper); // SELECT id,order_msg FROM my_mysql.order WHERE (order_msg = '572')

QueryChainWrapper

QueryChainWrapper<OrderEntity> queryChainWrapper = new QueryChainWrapper<>(orderMapper).select("id", "order_msg").eq("order_msg","573");
queryChainWrapper.one(); // SELECT id,order_msg FROM my_mysql.order WHERE (order_msg = '573')

LambdaQueryChainWrapper

LambdaQueryChainWrapper<OrderEntity> lambdaQueryChainWrapper = new LambdaQueryChainWrapper<>(orderMapper).select(OrderEntity::getId, OrderEntity::getOrderMsg).eq(OrderEntity::getOrderMsg,"574");
lambdaQueryChainWrapper.one(); // SELECT id,order_msg FROM my_mysql.order WHERE (order_msg = '574')

总结

QueryWrapper 和 lambdaQueryWrapper 需要将 封装的wrapper 提供给 orderMapper,调用orderMapper的方法,才可以使用。
QueryChainWrapper 和 LambdaQueryChainWrapper 可以直接链式调用数据执行操作的方法
带 lambda 的 wrapper 可以使用lambda表达式,选择列,设置列值,反之不带lambda的就需要手动指定列名

原文链接:https://blog.csdn.net/weixin_39973810/article/details/128465746

  • 上一篇:没有了
  • 下一篇:没有了
栏目分类
最近更新