急!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增加的查询条件,怎么解决这个问题

方法一:第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;
	 }

 

可以先查询query1,再查询query2
或者看看query有没有clone或者其他复制属性的,复制成另外一个对象

第一个查询,使用query1条件查询,第二个查询条件包含query1,为什么不直接在query1,后面继续添加条件,然后使用query1呢?

创建两个querwrapper对象没什么意义吧。

dao层写一个原生sql