当前位置: 首页 > news >正文

巨好用企业网站源码如何制作自己的网站?

巨好用企业网站源码,如何制作自己的网站?,深圳华强北今晚,怎么用电脑做网站服务器吗MyBatis-Plus 是一个基于 MyBatis 的增强工具,它提供了一套方便的注解方式来进行 SQL 查询。其中,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。 官网:条件构造器 | MyBatis-Plus 1、使用 Wrapper …

MyBatis-Plus 是一个基于 MyBatis 的增强工具,它提供了一套方便的注解方式来进行 SQL 查询。其中,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。

官网:条件构造器 | MyBatis-Plus

1、使用 Wrapper 自定义SQL注意事项

 需要mybatis-plus版本 >= 3.0.7

2、直接通过一个简单的示例进行讲解:

假设我们有一个名为"Order"的表,包含"orderId"和"amount"两列:

import lombok.Data;
import java.math.BigDecimal;
import java.time.LocalDateTime;@Data
public class Order {private Long orderId;private Long userId;private BigDecimal amount;private LocalDateTime createTime;
}

 现在,我们要查询某个用户在指定时间范围内的订单金额总和。可以按照以下方式编写代码:

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.reflection.Constants;public interface OrderMapper extends BaseMapper<Order> {@Select("select sum(amount) from `order` ${ew.customSqlSegment}")BigDecimal queryTotalAmountByUserAndDate(@Param(Constants.WRAPPER) LambdaQueryWrapper<Order> wrapper);
}

在上述代码中,我们定义了一个接口OrderMapper,继承自BaseMapper<Order>,并添加了一个方法queryTotalAmountByUserAndDate用于查询订单金额总和。LambdaQueryWrapper<Order>用于构建查询条件。


接下来,在你的业务逻辑代码中,可以按照以下方式使用该方法:

import java.math.BigDecimal;
import java.time.LocalDateTime;// ...private BigDecimal queryTotalAmountByUserAndDate(Long userId, LocalDateTime begin, LocalDateTime end) {LambdaQueryWrapper<Order> wrapper = new LambdaQueryWrapper<Order>().eq(Order::getUserId, userId).between(Order::getCreateTime, begin, end);BigDecimal totalAmount = orderMapper.queryTotalAmountByUserAndDate(wrapper);return totalAmount == null ? BigDecimal.ZERO : totalAmount;
}

在上述代码中,我们创建了一个LambdaQueryWrapper<Order>对象,并使用eq方法和between方法分别指定了用户ID和时间范围的条件。

然后,我们调用queryTotalAmountByUserAndDate方法,并传入该wrapper对象进行查询。最后,根据查询结果判断并返回订单金额总和。 


3、具体分析二者是如何结合使用的

(1)当使用SQL和Wrapper结合进行查询时,SQL用于编写具体的SQL语句,而Wrapper用于构建查询条件。

(2)SQL语句中的${ew.customSqlSegment}会被Wrapper对象中的条件替换,从而形成最终的SQL查询语句。Wrapper对象中的条件会根据具体的方法调用来生成相应的SQL片段,并替换${ew.customSqlSegment}


在示例中:

我们使用了LambdaQueryWrapper作为Wrapper对象,它提供了一系列方法来构建查询条件,如eqbetween等。

同时,我们在SQL语句中使用了sum(amount)来求和,这个部分是纯粹的SQL语法。

最后,通过调用queryTotalAmountByUserAndDate方法,我们将Wrapper对象传递给Mapper接口的查询方法,并使用${ew.customSqlSegment}将Wrapper中的条件注入到SQL语句中。执行查询后,得到的结果会返回给调用方。

(3)综上所述,SQL和Wrapper的结合使用,可以通过Wrapper构建查询条件,然后将条件注入到SQL语句中,从而实现灵活的查询操作。


4、这样使用的原因

因为,MyBatis-Plus并没有直接提供对于SUM求和的方法。你可以使用MyBatis-Plus的@Select注解结合自定义SQL来实现对某个字段的求和操作,并且通过Wrapper构建查询条件,简直不要太好用哦!!!

http://www.dinnco.com/news/57253.html

相关文章:

  • 只有一个人网站开发谷歌seo服务商
  • 群晖nas做网站性能如何在网上做销售推广
  • 光山县住房和城乡建设局网站网络营销推广优化
  • 济南产品网站建设外包百度seo排名360
  • 自己怎么做独立外贸网站福州seo快速排名软件
  • 做pc端网站价格品牌公关公司
  • 泉州网站开发企业seo入门课程
  • 网络管理员需要懂网站建设吗seo 百度网盘
  • 珠海电商网站制作咸阳网络推广
  • 自己用wordpress建站外包项目接单平台
  • 台州网页设计招聘信息兰州网络优化seo
  • 用ps如何做网站首页网络推广平台几大类
  • 目字形布局结构的网站seo推广是什么
  • 手机壁纸网站源码外链推广网站
  • 企业网站系统排名百度网站提交
  • 南京 网站开发要做网络推广
  • 郑州网站建设策划方案百度风云榜小说榜排名
  • 上海专业高端网站建设服sem是什么意思?
  • 中山网站建设文化报价软文的本质是什么
  • 网站做超链接薪资多少一个月网络广告类型
  • 江阴网络公司做网站独立站建站平台
  • 襄阳网站建设公司网络营销软文范例
  • 网站内容怎么选择一站式软文发布推广平台
  • 网站开发外包公司关键词林俊杰mp3在线听
  • 在线oa免费crm东莞市网络seo推广价格
  • 如何用百度搜自己做的网站温州seo结算
  • 山东省住房和城乡建设厅举报电话做百度seo
  • 湖南北山建设集团股份有限公司官方网站品牌传播方案
  • 正邦做网站多少钱廊坊seo排名扣费
  • 淘客网站建设教程免费搭建网站的软件