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

Java中Mybatis-Plus使用方式介紹

 更新時間:2023年06月01日 11:31:28   作者:顏淡慕瀟  
Mybatis-Plus提供了多種方式來執(zhí)行SQL,包括使用注解、XML映射文件和?Lambda表達式等,其中,使用Lambda表達式是Mybatis-Plus推薦的方式,因為它更加直觀和類型安全,,需要的朋友可以參考下

1 Mybatis-Plus簡介

Mybatis-Plus 提供了多種方式來執(zhí)行 SQL,包括使用注解、XML 映射文件和 Lambda 表達式等。其中,使用 Lambda 表達式是 Mybatis-Plus 推薦的方式,因為它更加直觀和類型安全。

2 使用方法

1  Lambda 表達式執(zhí)行 SQL

以下是一個使用 Lambda 表達式執(zhí)行 SQL 的示例,現(xiàn)在我們有一個名為 User 的實體類,其中包含 idname 和 age 屬性:

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
    @Override
    public List<User> getUsersByName(String name) {
        LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(User::getName, name);
        return baseMapper.selectList(queryWrapper);
    }
}

在這個示例中,我創(chuàng)建了一個 LambdaQueryWrapper 對象,使用 eq 方法指定查詢條件為 name = #{name},其中 #{name} 是參數(shù)占位符。

然后,調(diào)用 baseMapper.selectList 方法執(zhí)行查詢,并返回查詢結果。

2 組合示例 

要傳遞參數(shù),可以將參數(shù)作為方法的參數(shù),并在查詢條件中使用 eq、ne、in、like 等方法指定參數(shù)值。

例如,假設要查詢年齡大于等于 minAge,小于等于 maxAge 的用戶,可以修改上面的示例代碼如下:

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
    @Override
    public List<User> getUsersByAge(int minAge, int maxAge) {
        LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.ge(User::getAge, minAge).le(User::getAge, maxAge);
        return baseMapper.selectList(queryWrapper);
    }
}

在這個示例中,我添加了一個新的方法 getUsersByAge,其中兩個參數(shù) minAge 和 maxAge 分別表示最小年齡和最大年齡。

使用 ge 方法指定年齡大于等于 minAge,使用 le 方法指定年齡小于等于 maxAge。

然后,調(diào)用 baseMapper.selectList 方法執(zhí)行查詢,并返回查詢結果。

3 復雜sql 

另外,如果需要執(zhí)行復雜的 SQL,例如聯(lián)合查詢、分組查詢等,可以使用 Mybatis-Plus 提供的 SQL 構建器,它可以幫助你構建復雜的 SQL 語句。

以下是一個使用 SQL 構建器執(zhí)行聯(lián)合查詢的示例,假設你有一個名為 Order 的實體類,其中包含 id、userId 和 amount 屬性,你需要查詢每個用戶的訂單總金額:

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;
import java.util.List;
import java.util.Map;
@Service
public class OrderServiceImpl extends ServiceImpl<OrderMapper, Order> implements OrderService {
    @Override
    public List<Map<String, Object>> getOrderAmountByUser() {
        QueryWrapper<Order> queryWrapper = new QueryWrapper<>();
        queryWrapper.select("user_id", "sum(amount) as total_amount")
                    .groupBy("user_id");
        return baseMapper.selectMaps(queryWrapper);
    }
}

在這個示例中,我創(chuàng)建了一個 QueryWrapper 對象,使用 select 方法指定要查詢的字段為 user_id 和 sum(amount) as total_amount,其中 sum(amount) 表示每個用戶的訂單總金額,as total_amount 是為結果集中的這個字段取別名。

然后,使用 groupBy 方法將結果按照 user_id 進行分組。

最后,調(diào)用 baseMapper.selectMaps 方法執(zhí)行查詢,并返回查詢結果。

注意,在使用 SQL 構建器執(zhí)行復雜的 SQL 語句時,需要使用正確的 SQL 語法,并且需要特別注意 SQL 注入的問題。

可以使用 Mybatis-Plus 提供的參數(shù)綁定方式來避免 SQL 注入問題,例如 #{param}、${param} 等方式。

3 其他注入sql的方式

Mybatis-Plus 提供了多種注入 SQL 的方式,包括使用注解、XML 映射文件和 Lambda 表達式等。

不同的注入方式適用于不同的場景和需求,可以根據(jù)具體情況選擇適合的方式。

以下是幾種常用的注入 SQL 的方式:

1 使用注解

可以使用 @Select@Update、@Delete、@Insert 注解來注入 SQL 語句。例如:

@Select("SELECT * FROM user WHERE name = #{name}")
List<User> selectByName(@Param("name") String name);

在這個示例中,使用 @Select 注解注入了一條查詢語句,其中 #{name} 表示參數(shù)占位符,@Param("name") 表示參數(shù)名稱。

使用這種方式注入 SQL 語句比較簡單,但是不夠靈活,不支持復雜的 SQL 語句。

2 使用 XML 映射文件

可以使用 XML 映射文件來注入 SQL 語句,這種方式可以支持復雜的 SQL 語句,并且可以將 SQL 和 Java 代碼分離。

例如:在 UserMapper.xml 文件中:

<?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.example.mapper.UserMapper">
    <select id="selectByName" resultType="User">
        SELECT * FROM user WHERE name = #{name}
    </select>
</mapper>

在 UserMapper.java 文件中:

List<User> selectByName(@Param("name") String name);

在這個示例中,將查詢語句寫在 XML 映射文件中,使用 <select> 標簽指定 SQL 語句,并使用 resultType 屬性指定返回結果類型。然后,在 Java 代碼中調(diào)用該方法即可。

以上就是Java之Mybatis-Plus使用方式介紹的詳細內(nèi)容,更多關于Java Mybatis-Plus使用方式的資料請關注腳本之家其它相關文章!

相關文章

最新評論