關(guān)于MyBatis各種SQL操作詳解
一、查詢(xún)一個(gè)實(shí)體類(lèi)對(duì)象
映射方法:User getUserById(@Param("id") int id);
映射文件:
<select id="getUserById" resultType="User">
select * from t_user where id = #{id}
</select>二、查詢(xún)一個(gè)List集合
映射方法:List<User> getAllUser();
映射文件
<select id="getAllUser" resultType="User">
select * from t_user
</select>注意:當(dāng)查詢(xún)的數(shù)據(jù)為多條時(shí),不能使用實(shí)體類(lèi)作為返回值,否則會(huì)拋出異常 TooManyResultsException;但是若查詢(xún)的數(shù)據(jù)只有一條,可以使用實(shí)體類(lèi)或集合作為返回值
三、查詢(xún)單個(gè)數(shù)據(jù)
映射方法:int getCount();
映射文件:
<select id="getCount" resultType="java.lang.Integer">
select count(id) from t_user
</select>四、查詢(xún)一條數(shù)據(jù)及多條數(shù)據(jù)到map集合
查詢(xún)一條數(shù)據(jù)到map集合
映射方法:Map<String,Object> getUserToMap(@Param("id") int id);
映射文件:
<select id="getUserToMap" resultType="java.util.Map">
select * from t_user where id = #{id}
</select>注意:將一條數(shù)據(jù)查詢(xún)到map集合中時(shí),map的鍵是表中的字段名,map的值是表中的數(shù)據(jù)
查詢(xún)多條數(shù)據(jù)到map集合
方式一:
映射方法:List<Map<String,Object>> getAllUserToMap();
映射文件:
<select id="getAllUserToMap" resultType="java.util.Map">
select * from t_user
</select>方式二:
映射方法:
@MapKey("id") Map<String,Object> getAllUserToMap();
映射文件:
<select id="getAllUserToMap" resultType="java.util.Map">
select * from t_user
</select>注意:
- 方式一中每條查出來(lái)的數(shù)據(jù)都對(duì)應(yīng)一個(gè)Map集合,然后再利用List集合將這些Map集合 組織起來(lái)
- 方式二中每條查出來(lái)的數(shù)據(jù)都存放在一個(gè)Map集合中,但是這個(gè)Map集合的鍵由映射方 法上方的@MapKey注解指定,而Map集合的值又是另外一個(gè)Map集合,作為值的Map 集合中鍵對(duì)應(yīng)表中字段名,值對(duì)應(yīng)表中數(shù)據(jù)
五、模糊查詢(xún)
映射方法:List<User> getUserByLike(@Param("mohu") String mohu);
映射文件:
<select id="getUserByLike" resultType="User">
<!--方式1-->
select * from t_user where username like '%${mohu}%'
<!--方式2-->
select * from t_user where username like concat("%",#{mohu},"%")
<!--方式3-->
select * from t_user where username like "%"#{mohu}"%"
</select>注意:不能使用 like '%#{mohu}%' 的方式,因?yàn)?{}會(huì)被解析成?,這個(gè)問(wèn)號(hào)會(huì)被當(dāng)成字符串的一 部分造成參數(shù)獲取失敗
六、批量刪除
映射方法:void deleteSomeUser(@Param("ids") String ids);
映射文件:
<delete id="deleteSomeUser">
delete from t_user where id in(${ids})
</delete>注意:這里獲取參數(shù)的方式是${},因?yàn)?{}會(huì)自動(dòng)添加引號(hào),如果使用#{}的方式會(huì)造成SQL語(yǔ)句解 析成 delete from t_user where id in('ids') 從而報(bào)錯(cuò)
七、動(dòng)態(tài)設(shè)置表名
映射方法:List<User> getUserList(@Param("table") String table);
映射文件:
<select id="getUserList" resultType="User">
select * from ${table}
</select>注意:這里使用${}是因?yàn)槭褂?{}時(shí)會(huì)自動(dòng)添加引號(hào),而表名不允許添加表名
八、執(zhí)行添加功能時(shí)獲取自增的主鍵
映射方法:void insertUser(User user);
映射文件:
<insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
insert into t_user values(null,#{username},#{password},#{age},#
{gender},#{email})
</insert>測(cè)試方法:
@Test
public void testInsertUser(){
SqlSession sqlSession = SqlSessionUtil.getSqlSession();
SpecialSQLMapper mapper = sqlSession.getMapper(SpecialSQLMapper.class);
User user = new User(null,"老六","1234567",36,"男","laoliu@qq.com");
mapper.insertUser(user);
System.out.println(user);//在這一步中打印出的User對(duì)象中可以看到自增的id,如果配置文件中不使 用useGeneratedKeys和keyProperty,則id仍然是null
}注意:這里的useGeneratedKeys設(shè)置使用自增主鍵為true,keyProperty是將獲取的主鍵值賦給實(shí)體對(duì)象中的某個(gè)屬性。這樣,在添加這個(gè)實(shí)體對(duì)象后,自增的主鍵也能在實(shí)體對(duì)象中獲得,而不需要進(jìn)行查詢(xún)
到此這篇關(guān)于關(guān)于MyBatis各種SQL操作詳解的文章就介紹到這了,更多相關(guān)MyBatis的SQL操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
面試題:java中為什么foreach中不允許對(duì)元素進(jìn)行add和remove
讀者遇到了一個(gè)比較經(jīng)典的面試題,也就是標(biāo)題上說(shuō)的,為什么 foreach 中不允許對(duì)元素進(jìn)行 add 和 remove,本文就詳細(xì)的介紹一下,感興趣的可以了解一下2021-10-10
Java連接Sql數(shù)據(jù)庫(kù)經(jīng)常用到的操作
這篇文章主要介紹了Java連接Sql數(shù)據(jù)庫(kù)經(jīng)常用到的操作的相關(guān)資料,需要的朋友可以參考下2016-02-02
基于Java編寫(xiě)一個(gè)實(shí)用的ExcelUtil工具類(lèi)
在項(xiàng)目中經(jīng)常遇到excel表格導(dǎo)入導(dǎo)出功能,每次都要重復(fù)寫(xiě)有關(guān)excel 的邏輯,所以本文直接使用Java編寫(xiě)一個(gè)實(shí)用的ExcelUtil工具類(lèi),希望對(duì)大家有所幫助2024-04-04
m1 Mac設(shè)置多jdk版本并動(dòng)態(tài)切換的實(shí)現(xiàn)
本文主要介紹 Mac 下如何安裝 JDK 并且多版本如何切換,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
SpringCloud Feign遠(yuǎn)程調(diào)用實(shí)現(xiàn)詳解
Feign是Netflix公司開(kāi)發(fā)的一個(gè)聲明式的REST調(diào)用客戶(hù)端; Ribbon負(fù)載均衡、 Hystrⅸ服務(wù)熔斷是我們Spring Cloud中進(jìn)行微服務(wù)開(kāi)發(fā)非?;A(chǔ)的組件,在使用的過(guò)程中我們也發(fā)現(xiàn)它們一般都是同時(shí)出現(xiàn)的,而且配置也都非常相似2022-11-11
MyBatis圖文并茂講解注解開(kāi)發(fā)一對(duì)多查詢(xún)
這篇文章主要介紹了SpringBoot中Mybatis注解一對(duì)多查詢(xún)的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
后端如何接收格式為x-www-form-urlencoded的數(shù)據(jù)
x-www-form-urlencoded格式是一種常見(jiàn)的HTTP請(qǐng)求數(shù)據(jù)格式,它將請(qǐng)求參數(shù)編碼為鍵值對(duì)的形式,以便于傳輸和解析,下面這篇文章主要給大家介紹了關(guān)于后端如何接收格式為x-www-form-urlencoded的數(shù)據(jù),需要的朋友可以參考下2023-05-05
java UDP通信客戶(hù)端與服務(wù)器端實(shí)例分析
這篇文章主要介紹了java UDP通信客戶(hù)端與服務(wù)器端,結(jié)合實(shí)例形式分析了java基于UDP通信的客戶(hù)端與服務(wù)器端具體實(shí)現(xiàn)技巧及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2020-01-01
Java ProcessBuilder執(zhí)行多次CMD命令的使用
本文介紹了Java的ProcessBuilder類(lèi),該類(lèi)用于執(zhí)行外部命令,通過(guò)ProcessBuilder,我們可以在Java程序中靈活地執(zhí)行多次CMD命令,并控制輸入輸出流以及工作目錄等,感興趣的可以了解一下2024-11-11

