Java Fluent Mybatis 項(xiàng)目工程化與常規(guī)操作詳解流程篇 下
前言
接著上一篇:Java Fluent Mybatis 項(xiàng)目工程化與常規(guī)操作詳解流程篇 上
倉(cāng)庫(kù)地址:GitHub倉(cāng)庫(kù)
查詢
定義查詢請(qǐng)求體
package com.hy.fmp.dto.req;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/** @Author huyi @Date 2021/10/20 19:37 @Description: 查詢條件 */
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class TestFluentMybatisQueryReq {
private String age;
private String name;
}
查詢寫(xiě)法1
查詢接口方法定義
/** * 查詢接口1 * * @param queryReq 查詢請(qǐng)求 * @return 列表 */ List<TestFluentMybatisEntity> query1(TestFluentMybatisQueryReq queryReq);
方法實(shí)現(xiàn),這里我們改用了mapper來(lái)實(shí)現(xiàn)一下官方給出的查詢語(yǔ)法模式。
package com.hy.fmp.service.Impl;
import cn.hutool.core.util.StrUtil;
import com.hy.fmp.dto.req.TestFluentMybatisQueryReq;
import com.hy.fmp.fluent.dao.intf.TestFluentMybatisDao;
import com.hy.fmp.fluent.entity.TestFluentMybatisEntity;
import com.hy.fmp.fluent.helper.TestFluentMybatisMapping;
import com.hy.fmp.fluent.mapper.TestFluentMybatisMapper;
import com.hy.fmp.fluent.wrapper.TestFluentMybatisQuery;
import com.hy.fmp.service.IBaseService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.HashMap;
import java.util.List;
/** @Author huyi @Date 2021/10/20 17:10 @Description: 基礎(chǔ)操作接口實(shí)現(xiàn) */
@Slf4j
@Service
public class BaseServiceImpl implements IBaseService {
@Autowired private TestFluentMybatisDao testFluentMybatisDao;
@Autowired private TestFluentMybatisMapper testFluentMybatisMapper;
@Override
public TestFluentMybatisEntity insertOrUpdate(TestFluentMybatisEntity param) {
testFluentMybatisDao.saveOrUpdate(param);
return param;
}
@Override
public List<TestFluentMybatisEntity> query1(TestFluentMybatisQueryReq queryReq) {
return testFluentMybatisMapper.listEntity(
new TestFluentMybatisQuery()
.selectAll()
.where
.age()
.eq(queryReq.getAge())
.and
.name()
.eq(queryReq.getName())
.end());
}
}
control層方法定義
@ApiOperation(value = "查詢數(shù)據(jù)1", notes = "查詢數(shù)據(jù)1")
@RequestMapping(value = "/query1", method = RequestMethod.POST)
@ResponseBody
public Result<List<TestFluentMybatisEntity>> query1(
@RequestBody TestFluentMybatisQueryReq queryReq) {
try {
return Result.ok(baseService.query1(queryReq));
} catch (Exception exception) {
return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);
}
}
調(diào)試一下接口

一眼望去貌似沒(méi)問(wèn)題,但是長(zhǎng)期后端開(kāi)發(fā)的朋友應(yīng)該能看出來(lái),這個(gè)實(shí)現(xiàn)方式如果一旦age或者name參數(shù)為空的話,那么肯定查不出結(jié)果。因?yàn)榘凑照Z(yǔ)句的寫(xiě)法,會(huì)強(qiáng)制比較age和name兩個(gè)參數(shù)。
我們將其中一個(gè)參數(shù)設(shè)置為空字符串試試看。

不出意料。現(xiàn)在我可以就該方法做調(diào)整,參數(shù)判斷然后替換select語(yǔ)句,為了更優(yōu)雅的實(shí)現(xiàn),我去官方文檔再找找。
查詢寫(xiě)法2
查詢方法2
package com.hy.fmp.service.Impl;
import cn.hutool.core.util.StrUtil;
import com.hy.fmp.dto.req.TestFluentMybatisQueryReq;
import com.hy.fmp.fluent.dao.intf.TestFluentMybatisDao;
import com.hy.fmp.fluent.entity.TestFluentMybatisEntity;
import com.hy.fmp.fluent.helper.TestFluentMybatisMapping;
import com.hy.fmp.fluent.mapper.TestFluentMybatisMapper;
import com.hy.fmp.fluent.wrapper.TestFluentMybatisQuery;
import com.hy.fmp.service.IBaseService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.HashMap;
import java.util.List;
/** @Author huyi @Date 2021/10/20 17:10 @Description: 基礎(chǔ)操作接口實(shí)現(xiàn) */
@Slf4j
@Service
public class BaseServiceImpl implements IBaseService {
@Autowired private TestFluentMybatisDao testFluentMybatisDao;
@Autowired private TestFluentMybatisMapper testFluentMybatisMapper;
@Override
public TestFluentMybatisEntity insertOrUpdate(TestFluentMybatisEntity param) {
testFluentMybatisDao.saveOrUpdate(param);
return param;
}
@Override
public List<TestFluentMybatisEntity> query1(TestFluentMybatisQueryReq queryReq) {
return testFluentMybatisMapper.listEntity(
new TestFluentMybatisQuery()
.selectAll()
.where
.age()
.eq(queryReq.getAge())
.and
.name()
.eq(queryReq.getName())
.end());
}
@Override
public List<TestFluentMybatisEntity> query2(TestFluentMybatisQueryReq queryReq) {
return testFluentMybatisMapper.listByMap(
true,
new HashMap<String, Object>() {
{
if (!StrUtil.hasEmpty(queryReq.getAge())) {
this.put(TestFluentMybatisMapping.age.column, queryReq.getAge());
}
if (!StrUtil.hasEmpty(queryReq.getName())) {
this.put(TestFluentMybatisMapping.name.column, queryReq.getName());
}
}
});
}
}
代碼說(shuō)明
我對(duì)比了一下官方文檔的寫(xiě)法,發(fā)現(xiàn)我這個(gè)版本的fm該listByMap方法多一個(gè)isColumn的布爾型參數(shù)。所以我追了一下源碼。

只影響錯(cuò)誤打印,主要就是設(shè)置的map參數(shù)必須要是列名或者實(shí)體對(duì)象內(nèi)的參數(shù)名。就不管了。
驗(yàn)證一下

沒(méi)什么問(wèn)題,還是可以查出來(lái)。
新問(wèn)題
但是按照這個(gè)查詢方法,如果兩個(gè)值都傳空字符串會(huì)查出全表數(shù)據(jù)嗎?
驗(yàn)證一下

咳咳,報(bào)錯(cuò)了。
所以我還是老老實(shí)實(shí)先把代碼參數(shù)判空優(yōu)化一下。
package com.hy.fmp.service.Impl;
import cn.hutool.core.util.StrUtil;
import com.hy.fmp.dto.req.TestFluentMybatisQueryReq;
import com.hy.fmp.fluent.dao.intf.TestFluentMybatisDao;
import com.hy.fmp.fluent.entity.TestFluentMybatisEntity;
import com.hy.fmp.fluent.helper.TestFluentMybatisMapping;
import com.hy.fmp.fluent.mapper.TestFluentMybatisMapper;
import com.hy.fmp.fluent.wrapper.TestFluentMybatisQuery;
import com.hy.fmp.service.IBaseService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.HashMap;
import java.util.List;
/** @Author huyi @Date 2021/10/20 17:10 @Description: 基礎(chǔ)操作接口實(shí)現(xiàn) */
@Slf4j
@Service
public class BaseServiceImpl implements IBaseService {
@Autowired private TestFluentMybatisDao testFluentMybatisDao;
@Autowired private TestFluentMybatisMapper testFluentMybatisMapper;
@Override
public TestFluentMybatisEntity insertOrUpdate(TestFluentMybatisEntity param) {
testFluentMybatisDao.saveOrUpdate(param);
return param;
}
@Override
public List<TestFluentMybatisEntity> query1(TestFluentMybatisQueryReq queryReq) {
return testFluentMybatisMapper.listEntity(
new TestFluentMybatisQuery()
.selectAll()
.where
.age()
.eq(queryReq.getAge())
.and
.name()
.eq(queryReq.getName())
.end());
}
@Override
public List<TestFluentMybatisEntity> query2(TestFluentMybatisQueryReq queryReq) {
if (StrUtil.hasEmpty(queryReq.getAge()) && StrUtil.hasEmpty(queryReq.getName())) {
return testFluentMybatisMapper.listEntity(new TestFluentMybatisQuery().selectAll());
}
return testFluentMybatisMapper.listByMap(
true,
new HashMap<String, Object>() {
{
if (!StrUtil.hasEmpty(queryReq.getAge())) {
this.put(TestFluentMybatisMapping.age.column, queryReq.getAge());
}
if (!StrUtil.hasEmpty(queryReq.getName())) {
this.put(TestFluentMybatisMapping.name.column, queryReq.getName());
}
}
});
}
}
驗(yàn)證一下

刪
添加通過(guò)ID刪除數(shù)據(jù)的接口方法
/** * 刪除接口 * * @param id id */ void deleteById(Integer id);
實(shí)現(xiàn)接口方法
@Override
public void deleteById(Integer id) {
testFluentMybatisMapper.deleteById(id);
}
驗(yàn)證一下


刪除成功
總結(jié)
這兩篇文章主要是將之前的項(xiàng)目進(jìn)行工程化改造,增加了文檔、接口等一些列常規(guī)化操作。實(shí)現(xiàn)了數(shù)據(jù)庫(kù)表的基本增刪改查功能。其他的功能會(huì)在之后慢慢更新,fm融合了很多其他orm框架的東西,需要慢慢摸索摸索。
如果本文對(duì)你有幫助,請(qǐng)點(diǎn)個(gè)贊支持一下吧。

到此這篇關(guān)于Java Fluent Mybatis 項(xiàng)目工程化與常規(guī)操作詳解流程篇 下的文章就介紹到這了,更多相關(guān)Java Fluent Mybatis內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java Fluent Mybatis實(shí)戰(zhàn)之構(gòu)建項(xiàng)目與代碼生成篇上
- Java Fluent Mybatis實(shí)戰(zhàn)之構(gòu)建項(xiàng)目與代碼生成篇下
- Fluent Mybatis實(shí)現(xiàn)環(huán)境隔離和租戶隔離
- Fluent Mybatis 批量更新的使用
- springboot 整合fluent mybatis的過(guò)程,看這篇夠了
- Fluent MyBatis實(shí)現(xiàn)動(dòng)態(tài)SQL
- Fluent Mybatis快速入門(mén)詳細(xì)教程
- Fluent Mybatis零xml配置實(shí)現(xiàn)復(fù)雜嵌套查詢
- Fluent Mybatis如何做到代碼邏輯和sql邏輯的合一
相關(guān)文章
Spring請(qǐng)求參數(shù)校驗(yàn)功能實(shí)例演示
這篇文章主要介紹了Spring請(qǐng)求參數(shù)校驗(yàn)功能實(shí)例演示,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-05-05
Java設(shè)計(jì)模式之策略模式的使用(Strategy?Pattern)
策略模式是一種行為型設(shè)計(jì)模式,用于定義一系列算法并將每個(gè)算法封裝起來(lái),使它們可以互相替換,從而實(shí)現(xiàn)代碼的可維護(hù)性和靈活性,策略模式包含策略接口、具體策略類(lèi)和上下文類(lèi),并通過(guò)將算法的選擇與使用分離,使得算法可以獨(dú)立變化2025-03-03
MyBatis中動(dòng)態(tài)SQL語(yǔ)句@Provider的用法
本文主要介紹了MyBatis中動(dòng)態(tài)SQL語(yǔ)句@Provider的用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
sharding-jdbc5.0.0實(shí)現(xiàn)分表實(shí)踐
本文主要介紹了sharding-jdbc5.0.0分表實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
SpringBoot中定制異常頁(yè)面的實(shí)現(xiàn)方法
這篇文章主要介紹了SpringBoot中定制異常頁(yè)面的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
java swing實(shí)現(xiàn)貪吃蛇雙人游戲
這篇文章主要為大家詳細(xì)介紹了java swing實(shí)現(xiàn)貪吃蛇雙人小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01
Java模擬計(jì)算機(jī)的整數(shù)乘積計(jì)算功能示例
這篇文章主要介紹了Java模擬計(jì)算機(jī)的整數(shù)乘積計(jì)算功能,簡(jiǎn)單分析了計(jì)算機(jī)數(shù)值進(jìn)制轉(zhuǎn)換與通過(guò)位移進(jìn)行乘積計(jì)算的原理,并結(jié)合具體實(shí)例給出了java模擬計(jì)算機(jī)成績(jī)運(yùn)算的相關(guān)操作技巧,需要的朋友可以參考下2017-09-09

