1 Mybatis-Plus簡介
Mybatis-Plus 提供了多種方式來執(zhí)行 SQL,包括使用注解、XML 映射文件和 Lambda 表達式等。其中,使用 Lambda 表達式是 Mybatis-Plus 推薦的方式,因為它更加直觀和類型安全。
2 使用方法
1??Lambda 表達式執(zhí)行 SQL
以下是一個使用 Lambda 表達式執(zhí)行 SQL 的示例,現(xiàn)在我們有一個名為?
User
?的實體類,其中包含?id
、name
?和?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í)行查詢,并返回查詢結(jié)果。
2 組合示例?
要傳遞參數(shù),可以將參數(shù)作為方法的參數(shù),并在查詢條件中使用?
eq
、ne
、in
、like
?等方法指定參數(shù)值。例如,假設(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í)行查詢,并返回查詢結(jié)果。
3 復(fù)雜sql??
另外,如果需要執(zhí)行復(fù)雜的 SQL,例如聯(lián)合查詢、分組查詢等,可以使用 Mybatis-Plus 提供的 SQL 構(gòu)建器,它可以幫助你構(gòu)建復(fù)雜的 SQL 語句。
以下是一個使用 SQL 構(gòu)建器執(zhí)行聯(lián)合查詢的示例,假設(shè)你有一個名為?
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
?是為結(jié)果集中的這個字段取別名。然后,使用?
groupBy
?方法將結(jié)果按照?user_id
?進行分組。最后,調(diào)用?
baseMapper.selectMaps
?方法執(zhí)行查詢,并返回查詢結(jié)果。
注意,在使用 SQL 構(gòu)建器執(zhí)行復(fù)雜的 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 語句比較簡單,但是不夠靈活,不支持復(fù)雜的 SQL 語句。
2 使用 XML 映射文件
可以使用 XML 映射文件來注入 SQL 語句,這種方式可以支持復(fù)雜的 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
?文件中:文章來源:http://www.zghlxwxcb.cn/news/detail-466695.html
List<User> selectByName(@Param("name") String name);
在這個示例中,將查詢語句寫在 XML 映射文件中,使用?
<select>
?標簽指定 SQL 語句,并使用?resultType
?屬性指定返回結(jié)果類型。然后,在 Java 代碼中調(diào)用該方法即可。文章來源地址http://www.zghlxwxcb.cn/news/detail-466695.html
到了這里,關(guān)于【Java系列】Mybatis-Plus 使用方式介紹的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!