LorryLu0416 2021-03-12 11:42 采纳率: 70%
浏览 4507
已采纳

急!JAVA:mybatis-plus中LambdaQueryWrapper条件查询器问题

同样的查询条件,一个query1用来查询数据,还有一个使用query1 的查询条件和其他的条件构建query2去查询数量,如下图示例

LambdaQueryWrapper<StudentInfo> query1 = Wrappers.<StudentInfo>lambdaQuery();
query1.查询条件1;
if ("1".equals(selectFlag) && "1".equals(type)) {
	LambdaQueryWrapper<StudentInfo> query2 = queryWrapper;
    query2.查询条件2;
    int count=count(query2);
}
List<StudentInfo> result = list(query1);

我是直接新建一个LambdaQueryWrapper对象,直接把query1赋值给新建的query2,然后query2直接去查询,但是发现用query1去查询数据的时候,query1的条件中加入了querr2增加的查询条件,怎么解决这个问题

  • 写回答

4条回答 默认 最新

  • tkzc_shark 2021-03-12 14:39
    关注

    方法一:第8行移到第3行

    方法二:使用深克隆复制对象

        public static Object deepCopy(Object src)  {
    		 @SuppressWarnings("unchecked")
    		 Object dest = null;
    		 try {
    			 ByteArrayOutputStream byteOut = new ByteArrayOutputStream();
    			 ObjectOutputStream out = new ObjectOutputStream(byteOut);
    			 out.writeObject(src);
    
    			 ByteArrayInputStream byteIn = new ByteArrayInputStream(byteOut.toByteArray());
    			 ObjectInputStream in = new ObjectInputStream(byteIn);
    			 dest =  in.readObject();
    		 } catch (IOException e) {
    			 e.printStackTrace();
    		 } catch (ClassNotFoundException e) {
    			 e.printStackTrace();
    		 }
    		 return dest;
    	 }
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据