多条件查询

实现查询功能
在这里插入图片描述

1创建查询条件的封装对象
在这里插入图片描述
生成其对应的有参无参构造器 和get set方法

2.dao层(mapper) 创建接口

在这里插入图片描述
3.mapper

<select id="selectConditionSplitPage" resultMap="BaseResultMap" parameterType="com.bjpowernode.pojo.vo.ProductVo">
select
<include refid="Base_Column_List"/>
from product_info
<!-- 拼条件 -->
<where>
 <!--商品名称不为空,拼接商品名称模糊查询-->
<if test="pname!=null and pname!=''"> and p_name like '%${pname}%' </if>
<!--商品类型不为空,拼接商品类型查询条件-->
<if test="typeid!=null and typeid!=-1"> and type_id =#{typeid} </if>
<!--如果最低价格不为空,最高价格为空,则查询大于最低价格的所有商品-->
<if test="(lprice!=null and lprice!='') and (hprice==null or hprice=='')"> and p_price >= #{lprice} </if>
<!--如果最高价格不为空,最低价格为空,则查询小于最高价格的所有商品-->
<if test="(lprice==null or lprice=='') and (hprice!=null and hprice!='')"> and p_price <= #{hprice} </if>
<!--查询位于最低价格与最高价格之间-->
<if test="(lprice!=null and lprice!='') and (hprice!=null and hprice!='')"> and p_price between #{lprice} and #{hprice} </if>
</where>
order by p_id desc
</select>

4.业务逻辑层

接口

List<ProductInfo> selectCondition(ProductInfoVo vo);

实现类

public List<ProductInfo> selectCondition(ProductInfoVo vo){
      return p.selectCondition(vo) ;
}

5.控制器开发(ajax的异步查询)

@RespnseBody
@RequestMapping("/condition")
public  void condition(ProductInfoVo vo,HttpSession session){

List<ProductInfo> list = p.selectCondition(vo);
session.serAttribute("list",list);
}

6.页面开发
在这里插入图片描述

1.取出查询条件

 var  pname =$("#pname").val();
 var  typeid =$("#typeid").val();
 var  lprice =$("#lprice").val();
 var  hprice =$("#hprice").val();

2.发送异步ajax请求

        $.ajax({
        type="post",
        url :"${pageContext.request.contextPath}/prod/condition.action",
        data:{"pname":pname,"typeid":typeid,"lprice":lprice,"hprice",hprice},
        success: function(){
         //进行刷新显示数据的容器
          $("#table").load("http://localhost:80/admin/product.jsp #table")}
});
function condition(){
 var  pname =$("#pname").val();
 var  typeid =$("#typeid").val();
 var  lprice =$("#lprice").val();
 var  hprice =$("#hprice").val();
         $.ajax({
        type="post",
        url :"${pageContext.request.contextPath}/prod/condition.action",
        data:{"pname":pname,"typeid":typeid,"lprice":lprice,"hprice",hprice},
        success: function(){
         //进行刷新显示数据的容器
          $("#table").load("http://localhost:80/admin/product.jsp #table")}
});
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值