1 Mybatis-Plus簡介
Mybatis-Plus 提供了多種方式來執行 SQL,包括使用注解、XML 映射文件和 Lambda 表達式等。其中,使用 Lambda 表達式是 Mybatis-Plus 推薦的方式,因為它更加直觀和類型安全。
2 使用方法
1 Lambda 表達式執行 SQL
以下是一個使用 Lambda 表達式執行 SQL 的示例,現在我們有一個名為 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);
}
}
在這個示例中,我創建了一個 LambdaQueryWrapper 對象,使用 eq 方法指定查詢條件為 name = #{name},其中 #{name} 是參數占位符。
然后,調用 baseMapper.selectList 方法執行查詢,并返回查詢結果。
2 組合示例
要傳遞參數,可以將參數作為方法的參數,并在查詢條件中使用 eq、ne、in、like 等方法指定參數值。
例如,假設要查詢年齡大于等于 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,其中兩個參數 minAge 和 maxAge 分別表示最小年齡和最大年齡。
使用 ge 方法指定年齡大于等于 minAge,使用 le 方法指定年齡小于等于 maxAge。
然后,調用 baseMapper.selectList 方法執行查詢,并返回查詢結果。
3 復雜sql
另外,如果需要執行復雜的 SQL,例如聯合查詢、分組查詢等,可以使用 Mybatis-Plus 提供的 SQL 構建器,它可以幫助你構建復雜的 SQL 語句。
以下是一個使用 SQL 構建器執行聯合查詢的示例,假設你有一個名為 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);
}
}
在這個示例中,我創建了一個 QueryWrapper 對象,使用 select 方法指定要查詢的字段為 user_id 和 sum(amount) as total_amount,其中 sum(amount) 表示每個用戶的訂單總金額,as total_amount 是為結果集中的這個字段取別名。
然后,使用 groupBy 方法將結果按照 user_id 進行分組。
最后,調用 baseMapper.selectMaps 方法執行查詢,并返回查詢結果。
注意,在使用 SQL 構建器執行復雜的 SQL 語句時,需要使用正確的 SQL 語法,并且需要特別注意 SQL 注入的問題。
可以使用 Mybatis-Plus 提供的參數綁定方式來避免 SQL 注入問題,例如 #{param}、${param} 等方式。
3 其他注入sql的方式
Mybatis-Plus 提供了多種注入 SQL 的方式,包括使用注解、XML 映射文件和 Lambda 表達式等。
不同的注入方式適用于不同的場景和需求,可以根據具體情況選擇適合的方式。
以下是幾種常用的注入 SQL 的方式:
1 使用注解
可以使用 @Select、@Update、@Delete、@Insert 注解來注入 SQL 語句。例如:
@Select("SELECT * FROM user WHERE name = #{name}")
List<User> selectByName(@Param("name") String name);
在這個示例中,使用 @Select 注解注入了一條查詢語句,其中 #{name} 表示參數占位符,@Param("name") 表示參數名稱。
使用這種方式注入 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 代碼中調用該方法即可。
本站文章版權歸原作者及原出處所有 。內容為作者個人觀點, 并不代表本站贊同其觀點和對其真實性負責,本站只提供參考并不構成任何投資及應用建議。本站是一個個人學習交流的平臺,網站上部分文章為轉載,并不用于任何商業目的,我們已經盡可能的對作者和來源進行了通告,但是能力有限或疏忽,造成漏登,請及時聯系我們,我們將根據著作權人的要求,立即更正或者刪除有關內容。本站擁有對此聲明的最終解釋權。