mybatisplus如何拼接动态sql

为了让代码更通用,为了让代码更简洁,所以有时候我们需要把查询条件动态化

后端代码如下:

java 复制代码
@GetMapping("/selectOrder")
    public R<Page> selectOrder(String openid,String query,int page, int pageSize){
        System.out.println("订单界面数据展示");
        System.out.println("接收到的openid,"+openid);
        System.out.println("接收到的query,"+query);
        System.out.println("接收到的page,"+page);
        System.out.println("接收到的pageSize,"+pageSize);
        //分页构造器
        Page<Xcx_2OrderData> pageInfo = new Page<>(page,pageSize);
        //条件构造器
        QueryWrapper<Xcx_2OrderData> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("openid",openid);
        // 当 query 不为空时,拼接上额外的查询条件
        // 使用 Hutool 将 query 字符串解析为 Map
        Map<String, Object> queryMap = JSONUtil.toBean(query, Map.class);

        // 遍历 Map,构造查询条件
        for (Map.Entry<String, Object> entry : queryMap.entrySet()) {
            String key = entry.getKey();
            Object value = entry.getValue();
            queryWrapper.eq(key, value);
        }
        // TODO 这里应该再加一个条件,因为用户如果进入支付输入密码界面的时候,这时候用户手机关机了
        // TODO 然后既不能微信通知中让我们改变其状态为未支付,也不能在前端取消支付时候也不会触发(也不能让我们改成未支付),这时候数据库
        // TODO 中的pay_success字段就是为null,而不是为待支付: not_pay字段,这会出现一个什么情况呢
        // TODO 就是说页面这种查全部可以查到,但是不属于其他四个任何一个分类,所以拼接pay_success字段不为null的值
        // TODO bububu,这里不拼接pay_success字段不为null的值了,直接给pay_success字段为null的值全部删掉即可
        QueryWrapper<Xcx_2OrderData> objectQueryWrapper = new QueryWrapper<>();
        objectQueryWrapper.isNull("pay_success");
        xcx_2OrderDataService.remove(objectQueryWrapper);

        //分页查询
        xcx_2OrderDataService.page(pageInfo,queryWrapper);
        return R.success(pageInfo);
    }

前端部分代码如下(requestApi是我封装的wx.request):

java 复制代码
// 请求数据
	const res_order = reactive({order_data:[]})
	const {order_data} = toRefs(res_order)
	async function getOrder(sk,query){
		const openid = wx.getStorageSync('openid')//取出本地缓存的用户信息
		// const res = await db.collection('order_data').where(query).limit(10).skip(sk).orderBy('order_time','desc').get()
		const res =await requestApi('/selectOrder',{openid:openid,query:query,page:sk,pageSize:10})
		console.log(res)
		res_order.order_data = [...res_order.order_data,...res.data.records]
	}
	
	
	// 上拉加载
	let loading = ref(false)
	let page_n = ref(1)
	onReachBottom(async()=>{//onReachBottom只能在父组件才能触底
		loading.value = true
		page_n.value++
		let sk = page_n.value * 10
		await getOrder(sk,data.tab[re.value].query)
		loading.value = false
	})
相关推荐
企鹅侠客6 分钟前
第35章—内核解析篇:Redis内存淘汰机制
数据库·redis
西柚小萌新17 分钟前
【人工智能:Agent】--12.多智能体(二)
数据库
快乐非自愿20 分钟前
【面试题】MySQL 的索引类型有哪些?
数据库·mysql·面试
naruto_lnq21 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
曹轲恒30 分钟前
【Redis持久化核心】AOF/RDB通俗详解+多场景对比
数据库·redis·bootstrap
冉冰学姐1 小时前
SSM疫情期间学生作业线上管理系统55zmw(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·计算机毕设·ssm作业管理系统
qq_12498707531 小时前
基于Srpingboot心晴疗愈社平台的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·spring·microsoft·毕业设计·计算机毕业设计
霖霖总总1 小时前
[小技巧55]深入解析数据库日志机制:逻辑日志、物理日志与物理逻辑日志在 MySQL InnoDB 中的实现
数据库·mysql
OceanBase数据库官方博客1 小时前
主流关系型数据库系统缺陷实证研究——OceanBase 校企联合研究
数据库·oceanbase·分布式数据库