欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis Plus使用條件構造器增刪改查功能的實現方法

 更新時間:2021年05月12日 09:30:29   作者:旺卡先生  
這篇文章主要介紹了Mybatis-Plus使用條件構造器增刪改查,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

java后端層級結構


Controller 接口層

接口層比較好理解,它是面向web網絡的接口,使用http格式去調用

/**
 * 圖文課程管理Controller
 */
@RestController
@RequestMapping("/driver/imageCourse")
public class TImageCourseController extends BaseController {
    
    @Autowired
    private ITImageCourseService tImageCourseService;
    @Autowired
    private TImageCourseMapper tImageCourseMapper;
    
    // 具體接口...
}

Service 業(yè)務層

在實際應用中,更復雜的邏輯應該寫在 Service 業(yè)務層方法中,在業(yè)務方法中再調用數據層方法,實現從 接口層-業(yè)務層-數據層 的鏈路調用關系,提高代碼的可讀性

/**
 * 圖文課程管理Service接口
 */
public interface ITImageCourseService extends IService<TImageCourse> {
}

業(yè)務層實現

/**
 * 圖文課程管理Service業(yè)務層處理
 */
@Service
public class TImageCourseServiceImpl extends ServiceImpl<TImageCourseMapper, TImageCourse> implements ITImageCourseService {
    @Autowired
    private TImageCourseMapper tImageCourseMapper;

}

ServiceImpl 類實現了 IService 接口中的方法;ServiceImpl 中的方法,本質上是對 BaseMapper 方法的封裝,同時也增加了一些 BaseMapper 類中沒有的特性,例如常用的 list() 、count() 方法

// Service方法調用了Mapper方法 只是將insert()返回轉換成了布爾值
@Override
public boolean save(T entity) {
    return retBool(baseMapper.insert(entity));
}

Mapper 數據層

繼承 BaseMapper 接口后,無需編寫 mapper.xml 文件,即可獲得CRUD功能;例如,insert()deleteById() 、updateById() 、 selectById() 等方法

如果手動編寫數據層的sql,BaseMapper實現者即對應xml中的sql方法

/**
 * 圖文課程管理Mapper接口
 */
public interface TImageCourseMapper extends BaseMapper<TImageCourse> {
}

**mapper.xml **

xml內容例子,該例子自定義了一個根據id的查詢方法,無視了刪除標志

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.mapper.TRuralInfoMapper">

    <resultMap type="TRuralInfo" id="RuralInfoResult">
        <id     property="id"             column="id"           />
        <result property="cityName"       column="city_name"    />
        <result property="countyName"     column="county_name"  />
        <result property="townName"       column="town_name"    />
        <result property="villageName"    column="village_name" />
        <result property="checkCode"      column="check_code"   />
        <result property="parentLevel"    column="parent_level" />
        <result property="parentId"       column="parent_id"    />
        <result property="delFlag"        column="del_flag"     />
        <result property="createBy"       column="create_by"    />
        <result property="createTime"     column="create_time"  />
        <result property="updateBy"       column="update_by"    />
        <result property="updateTime"     column="update_time"  />
    </resultMap>

    <sql id="selectRuralInfoVo">
        select t_rural_info.id, city_name, county_name, town_name, village_name, check_code, parent_level, parent_id,
        t_rural_info.del_flag, t_rural_info.create_by, t_rural_info.create_time, t_rural_info.update_by, t_rural_info.update_time
        from t_rural_info
    </sql>

    <select id="getRuralInfoById" parameterType="Long" resultMap="RuralInfoResult">
        <include refid="selectRuralInfoVo"/>
        where id = #{id}
    </select>
</mapper>

增刪改查


新增(C)

使用 mapper 對象的 insert() 方法新增一條記錄,成果后會將數據庫的id返回給實體

/**
 * 新增圖文課程管理
 */
@PostMapping
public AjaxResult add(@RequestBody TImageCourse tImageCourse)
{    
    ...
    return toAjax(tImageCourseMapper.insert(tImageCourse));
}

saveBatch

service 類中提供了 saveBatch() 方法,可實現批量插入,該方法是支持事務

saveOrUpdate

service 類中提供了 saveOrUpdate() 方法,如果id為空則調用 save() 方法保存,反之則調用 updateById() 方法更新

查詢(R)

查詢多數要借助條件構造器使用才有意義,實現更靈活的查詢;

查詢實體

常用的方法有 .getOne()getById() ;

.getOne() 接收一個條件構造器作為參數

getById() 根據id進行查詢實體

查詢集合

常用的查詢方法包括 .list()

.list() 方法也可以接收一個條件構造器作為參數

構造器的使用

條件構造器包含 QueryWrapperLambdaQueryWrapper 兩個類。

LambdaQueryWrapper 為函數式編程的書寫習慣,與 QueryWrapper 表達的意義相同,優(yōu)點是簡化了代碼。

此處以 LambdaQueryWrapper 的使用為例,常用的三種方法:

// 1、直接用new創(chuàng)建
// 創(chuàng)建對象的方式會更加靈活,可配合 if()...else 達到更靈活的sql拼接
LambdaQueryWrapper<TCenterPoint> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(TCenterPoint::getPoint, 10.0);

// 2、靜態(tài)方法創(chuàng)建 Wrappers.<>lambdaQuery()
// 構造器方法多為鏈式編程 可連寫
Wrappers.<TCenterPoint>lambdaQuery().eq(TCenterPoint::getPoint, 10.0)

// 3、靜態(tài)方法創(chuàng)建 Wrappers.query() 
// query可接受對象 字段不為null則自動拼接.eq()方法
Wrappers.query(tUserDetail)

構造器方法

/**
 * 源碼
 * @param condition 執(zhí)行條件 可省略
 * @param column    字段
 * @param val       值
 */
eq(boolean condition, R column, Object val)
eq 相等 =
ne 不等于 !=
gt 大于 >
ge 大于等于 >=
lt 小于 <
le 小于等于 <=
between BETWEEN 值1 AND 值2
like LIKE ‘%值%'
notLike NOT LIKE ‘%值%'
likeLeft LIKE ‘%值' ; likeRight同理
isNull 字段 IS NULL;
orderByAsc 排序:ORDER BY 字段, … ASC; orderByDesc同理

在sql中使用and和or,邏輯只需寫在where中即可,在ORM框架中較為不好理解,總之,其結果是實現一個查詢條件和多個條件并列的關系

OR

or(Consumer<Param> consumer)
or(boolean condition, Consumer<Param> consumer)

OR 嵌套,例如

// or (name = '李白' and status <> '活著')
or(i -> i.eq("name", "李白").ne("status", "活著"))

AND

and(Consumer<Param> consumer)
and(boolean condition, Consumer<Param> consumer)

AND 嵌套,例如

// and (name = '李白' and status <> '活著')
and(i -> i.eq("name", "李白").ne("status", "活著"))

修改(U)

使用 mapper 對象的 updateById() 方法更新實體,只有字段內容不為空,才會觸發(fā)字段內容的修改

/**
 * 修改圖文課程管理
 */
@PutMapping
public AjaxResult edit(@RequestBody TImageCourse tImageCourse)
{
    return toAjax(tImageCourseMapper.updateById(tImageCourse));
}

刪除(D)

刪除常用的方法是根據id進行刪除,使用 mapper 對象的 deleteById ,框架也支持批量刪除的操作 deleteBatchIds

/**
 * 刪除圖文課程管理
 */
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids) {
    return toAjax(tImageCourseMapper.deleteBatchIds(Arrays.asList(ids)));
}

到此這篇關于Mybatis-Plus使用條件構造器增刪改查的文章就介紹到這了,更多相關Mybatis Plus條件構造器增刪改查內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • SpringBoot3和mybatis-plus整合出現的問題解決辦法

    SpringBoot3和mybatis-plus整合出現的問題解決辦法

    SpringBoot和MybatisPlus的整合可以讓我們更加方便地進行數據庫操作,這篇文章主要給大家介紹了關于SpringBoot3和mybatisplus整合出現的一些問題的相關資料,需要的朋友可以參考下
    2024-01-01
  • Java8中Optional操作的實際應用

    Java8中Optional操作的實際應用

    Optional類是一個可以為null的容器對象,如果值存在則isPresent()方法會返回true,調用get()方法會返回該對象,下面這篇文章主要給大家介紹了關于Java8中Optional操作實際應用的相關資料,需要的朋友可以參考下
    2022-02-02
  • Java使用ScriptEngine動態(tài)執(zhí)行代碼(附Java幾種動態(tài)執(zhí)行代碼比較)

    Java使用ScriptEngine動態(tài)執(zhí)行代碼(附Java幾種動態(tài)執(zhí)行代碼比較)

    這篇文章主要介紹了Java使用ScriptEngine動態(tài)執(zhí)行代碼,并且分享Java幾種動態(tài)執(zhí)行代碼比較,需要的朋友可以參考下
    2021-04-04
  • Mybatis常用標簽及屬性小結

    Mybatis常用標簽及屬性小結

    這篇文章主要介紹了Mybatis常用標簽及屬性小結,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12
  • Spring?Boot?整合RocketMq實現消息過濾功能

    Spring?Boot?整合RocketMq實現消息過濾功能

    這篇文章主要介紹了Spring?Boot?整合RocketMq實現消息過濾,本文講解了RocketMQ實現消息過濾,針對不同的業(yè)務場景選擇合適的方案即可,需要的朋友可以參考下
    2022-06-06
  • Java 服務端消息推送的實現小結

    Java 服務端消息推送的實現小結

    本文主要介紹了Java 服務端消息推送的實現小結,主要包括四種常見的消息實時推送方案:短輪詢、長輪詢、SSE?和?WebSocket,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • 我用java實現了王者榮耀的皮膚和英雄技能

    我用java實現了王者榮耀的皮膚和英雄技能

    上篇文章主要實現了創(chuàng)建英雄,創(chuàng)建野怪,創(chuàng)建裝備.并且實現了簡單的刷怪,購買裝備等.本篇文章我優(yōu)化了我的操作界面,并且實現了英雄技能,英雄皮膚等,需要的朋友可以參考下
    2021-05-05
  • 使用ObjectMapper解析json不用一直new了

    使用ObjectMapper解析json不用一直new了

    這篇文章主要為大家介紹了使用ObjectMapper解析json不用一直new了的方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • java循環(huán)練習的簡單代碼實例

    java循環(huán)練習的簡單代碼實例

    本篇文章介紹了,java中循環(huán)練習的一些簡單代碼實例。需要的朋友參考下
    2013-04-04
  • 深入理解Java設計模式之享元模式

    深入理解Java設計模式之享元模式

    這篇文章主要介紹了JAVA設計模式之享元模式的的相關資料,文中示例代碼非常詳細,供大家參考和學習,感興趣的朋友可以了解下
    2021-11-11

最新評論