這篇文章主要介紹了怎么利用反射生成MyBatisPlus中QueryWrapper動態條件的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇怎么利用反射生成MyBatisPlus中QueryWrapper動態條件文章都會有所收獲,下面我們一起來看看吧。
在MyBatisPlus中經常會用到如下所示的代碼來構造查詢條件:
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
if (userQuery.getId() != null) {
queryWrapper.eq("id", userQuery.getId());
}
if (userQuery.getName() != null) {
queryWrapper.like("name", userQuery.getName());
}
if (userQuery.getNickname() != null) {
queryWrapper.like("nickname", userQuery.getNickname());
}
if (userQuery.getAccount() != null) {
queryWrapper.eq("account", userQuery.getAccount());
}
if (userQuery.getGender() != null) {
queryWrapper.eq("gender", userQuery.getGender());
}
if (userQuery.getBirth2() != null) {
queryWrapper.ge("birth", userQuery.getBirth2());
}
if (userQuery.getBirth3() != null) {
queryWrapper.le("birth", userQuery.getBirth3());
}
if (userQuery.getTel() != null) {
queryWrapper.eq("tel", userQuery.getTel());
}
if (userQuery.getEmail() != null) {
queryWrapper.eq("email", userQuery.getEmail());
}
if (userQuery.getQq() != null) {
queryWrapper.eq("qq", userQuery.getQq());
}
if (userQuery.getWechat() != null) {
queryWrapper.eq("wechat", userQuery.getWechat());
}
if (userQuery.getHomePage() != null) {
queryWrapper.eq("home_page", userQuery.getHomePage());
}
//.........
baseMapper.selectPage(page, queryWrapper);大量這樣的代碼,可以通過如下所示的反射技術生成,從而一勞永安逸,
public class APP{
public static void main(String[] args) throws Exception {
QueryWrapper<Dept> queryWrapper = new QueryWrapper<>();
Dept dept = Dept.builder()
.deptno(1234)
// .dname("sales")
.loc("NEWYORK")
.build();
Method[] methods = Dept.class.getDeclaredMethods();
for (Method method : methods) {
String methodName = method.getName();
if (methodName.contains("get")) {
Object res = method.invoke(dept, null);
if(res != null){
String columnName = getColumnName(methodName);
queryWrapper.eq(columnName,res);
}
}
}
System.out.println(queryWrapper);//在此處設置斷點,可以查看保存到QueryWrapper中的值
}
// 根據getter方法名得到對應表的字段名
public static String getColumnName(String name) {
StringBuffer sb = new StringBuffer();
name = name.substring(3, name.length()); //去掉get前綴
char[] chars = name.toCharArray();
for (int i = 0; i < chars.length; i++) {
char item = chars[i];
if (item > 65 && item < 90) {//大寫字母
sb.append("_");
sb.append((char)(item+32));
}else {
sb.append(item);
}
}
return sb.deleteCharAt(0).toString();
}
}關于“怎么利用反射生成MyBatisPlus中QueryWrapper動態條件”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“怎么利用反射生成MyBatisPlus中QueryWrapper動態條件”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。