同样的查询条件,一个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