對于mybatis和mybatisplus的選擇
- 1. 問題
- 2. MP單表操作
- 2.1 單表普通查詢
- 2.2 單表分頁查詢
- 3. mybatis多表操作
- 3.1 多表普通查詢
- 3.2 多表分頁查詢
1. 問題
mybatis 和 mybatisplus作為當下主流的持久層框架,各有優劣勢。依據個人經驗:mybatis可以定制化輸出數據庫操作,但是卻需要手寫sql和mapper以及service中的方法;mybatisplus雖然少了手寫sql和一些mapper以及service方法,但是對于多表操作的便捷性還是有很大不足。按照我的習慣,更偏向于mybatisplus+mybatis結合使用,在單表操作時利用MP提高效率;在多表操作時,利用mybatis。
2. MP單表操作
mp的一些常規操作
2.1 單表普通查詢
QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("age", 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );
2.2 單表分頁查詢
// 條件查詢
LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
// 分頁對象
Page<UserInfo> queryPage = new Page<>(page, limit);
// 分頁查詢
IPage<UserInfo> iPage = userInfoMapper.selectPage(queryPage , queryWrapper);
// 數據總數
Long total = iPage.getTotal();
// 集合數據
List<UserInfo> list = iPage.getRecords();
3. mybatis多表操作
3.1 多表普通查詢
List<Country> list = countryMapper.selectAll();
3.2 多表分頁查詢
//獲取第1頁,10條內容,默認查詢總數count
PageHelper.startPage(1, 10);
List<Country> list = countryMapper.selectAll();
//用PageInfo對結果進行包裝
PageInfo page = new PageInfo(list);