MyBatis代理Dao方式的增刪改查的實(shí)現(xiàn)小結(jié)
首先創(chuàng)建MavenJava項(xiàng)目
1.UserMapper接口代碼
package cn.tx.mapper;
?
import java.util.List;
?
import cn.tx.domain.User;
?
public interface UserMapper {
public List<User> findAll();
public User findById(Integer userId);
public void insert(User user);
public void update(User user);
public void delete(Integer userId);
public List<User> findByName(String username);
public Integer findByCount();
}2.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.qcbyjy.mapper.UserMapper">
<select id="findAll" resultType="com.qcbyjy.domain.User">
select * from user
</select>
<!--
通過id查詢
SQL語句使用#{占位符的名稱,名稱可以任意},僅限于基本數(shù)據(jù)類型和String類型
-->
<select id="findById" resultType="com.qcbyjy.domain.User" parameterType="int">
select * from user where id = #{id};
</select>
<!--保存操作-->
<insert id="insert" parameterType="com.qcbyjy.domain.User">
/*
keyProperty表示要返回的屬性名稱
order取值A(chǔ)FTER表示插入數(shù)據(jù)后的行為
resultType表示返回值的類型
*/
<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
select last_insert_id();
</selectKey>
insert into user (username,birthday,sex,address) values (#{username},#{birthday},#{sex},#{address})
</insert>
<!-- 修改 -->
<update id="update" parameterType="com.qcbyjy.domain.User">
update user set username = #{username},birthday = #{birthday},sex = #{sex},address=#{address} where id = #{id}
</update>
<!-- 刪除 -->
<delete id="delete" parameterType="Integer">
delete from user where id = #{id}
</delete>
<!-- 模糊查詢 -->
<select id="findByName" resultType="com.qcbyjy.domain.User" parameterType="string">
<!-- 第一種方式的SQL語句
select * from user where username like #{username}
-->
<!-- 第二章SQL語句的編寫 強(qiáng)調(diào):'%${value}%'不能修改,固定寫法(不推薦使用) -->
select * from user where username like '%${value}%'
</select>
<!-- 具體函數(shù)的查詢 -->
<select id="findByCount" resultType="int">
select count(*) from user
</select>
</mapper>3.UserTest的代碼
package cn.tx.test;
?
import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.List;
?
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
?
import cn.tx.domain.User;
import cn.tx.mapper.UserMapper;
?
public class UserTest {
private InputStream in;
private SqlSession session;
private UserMapper mapper;
@Before
public void init() throws Exception {
// 加載配置文件
in = Resources.getResourceAsStream("SqlMapConfig.xml");
// 創(chuàng)建工廠對(duì)象
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);
// 創(chuàng)建Session對(duì)象
session = factory.openSession();
// 獲取到代理對(duì)象
mapper = session.getMapper(UserMapper.class);
}
@After
public void destory() throws IOException {
in.close();
session.close();
}
/**
* 測(cè)試查詢所有的方法
* @throws Exception
*/
@Test
public void testFindAll() throws Exception {
List<User> list = mapper.findAll();
// 遍歷
for (User user : list) {
System.out.println(user);
}
in.close();
}
@Test
public void testFindById() throws Exception {
User user = mapper.findById(41);
System.out.println(user);
in.close();
}
?
@Test
public void testInsert() throws Exception {
User user = new User();
user.setUsername("美美");
user.setBirthday(new Date());
user.setSex("男");
user.setAddress("順義");
mapper.insert(user);
session.commit();
System.out.println(user.getId());
}
@Test
public void testUpdate() throws Exception {
User user = mapper.findById(41);
user.setUsername("小鳳");
mapper.update(user);
session.commit();
}
@Test
public void testDelete() throws Exception {
mapper.delete(48);
session.commit();
}
// 第一種
@Test
public void testFindByName() throws Exception {
List<User> list = mapper.findByName("%王%");
for (User user : list) {
System.out.println(user);
}
}
// 第二種
@Test
public void testFindByName() throws Exception {
List<User> list = mapper.findByName("王");
for (User user : list) {
System.out.println(user);
}
}
@Test
public void testFindByCount() throws Exception {
Integer count = mapper.findByCount();
System.out.println("總記錄數(shù):"+count);
}
}模糊查詢符號(hào)使用區(qū)別
1.#{}
UserMapper.xml
<select id="findByName" parameterType="string" resultType="com.qcby.pojo.User">
select * from user where username like #{username};
</select>測(cè)試類
@Test
public void findByNameTest(){
List<User> list=userMapper.findByName("%熊%");
for (User user:list){
System.out.println(user);
}
}
2.${}
UserMapper.xml
<select id="findByName2" parameterType="string" resultType="com.qcby.pojo.User">
select * from user where username like '%${value}%';
</select>
測(cè)試類
@Test
public void findByNameTest2(){
List<User> list=userMapper.findByName2("熊");
for (User user:list){
System.out.println(user);
}
}3.模糊查詢符號(hào)使用的區(qū)別
(1)#{}相當(dāng)于JDBC的占位符,可以有效防止sql注入
${}相當(dāng)于字符串拼接,容易引起sql注入問題
(2)#{}可以接收簡單類型值或pojo屬性值,如果parameterType傳輸單個(gè)簡單類型值,#{}括號(hào)里可以是value或其他名稱
${}可以接收簡單類型值或pojo屬性值,如果parameterType傳輸單個(gè)簡單類型值,${}括號(hào)中只能是value
(3)#{}like模糊查詢,xml配置文件中可以直接寫: ... like #{username}
${}like模糊查詢,需要加兩個(gè)%: ... like '%${value}%'
(4).${}方式一般用于傳入數(shù)據(jù)庫對(duì)象,例如列表和表名,#{}方式一般用來傳遞接口傳輸過來的具體數(shù)據(jù)。
(5)由于#{}方式具有更高的安全行,所以能用#{}的地方盡量不要使用${}。
(6).Mybatis排序時(shí)使用order by動(dòng)態(tài)參數(shù)時(shí)需要注意,用${}而不是#{}。
到此這篇關(guān)于MyBatis代理Dao方式的增刪改查的實(shí)現(xiàn)小結(jié)的文章就介紹到這了,更多相關(guān)MyBatis代理Dao增刪改查內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Centos下SpringBoot項(xiàng)目啟動(dòng)與停止腳本的方法
這篇文章主要介紹了Centos下SpringBoot項(xiàng)目啟動(dòng)與停止腳本的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11
SpringBoot使用Guava實(shí)現(xiàn)日志脫敏的示例代碼
本文主要介紹了SpringBoot使用Guava實(shí)現(xiàn)日志脫敏的示例代碼,使用Guava中的Strings、Maps和CharMatcher類來進(jìn)行日志脫敏,保護(hù)敏感數(shù)據(jù)的安全,感興趣的可以了解一下2024-01-01
SpringCloud?服務(wù)注冊(cè)中的nacos實(shí)現(xiàn)過程
這篇文章主要介紹了SpringCloud?服務(wù)注冊(cè)之nacos實(shí)現(xiàn)過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
使用Java讀取本地文件并轉(zhuǎn)換為MultipartFile對(duì)象的方法
在許多Java Web應(yīng)用中,我們經(jīng)常會(huì)遇到將本地文件上傳至服務(wù)器或其他系統(tǒng)的需求,在這種場(chǎng)景下,MultipartFile對(duì)象非常常用,用來表示HTTP請(qǐng)求中的文件,在本文中,我將演示如何編寫代碼來讀取本地文件并將其轉(zhuǎn)換為自定義的MultipartFile對(duì)象,需要的朋友可以參考下2025-08-08
Java并發(fā)系列之AbstractQueuedSynchronizer源碼分析(獨(dú)占模式)
這篇文章主要為大家詳細(xì)介紹了Java并發(fā)系列之AbstractQueuedSynchronizer源碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
詳解Java正則表達(dá)式中Pattern類和Matcher類
java.util.regex是一個(gè)用正則表達(dá)式所訂制的模式來對(duì)字符串進(jìn)行匹配工作的類庫包。包括兩個(gè)類Pattern和Matcher Pattern,Pattern是一個(gè)正則表達(dá)式經(jīng)編譯后的表現(xiàn)模式。Matcher對(duì)象是一個(gè)狀態(tài)機(jī)器,它依據(jù)Pattern對(duì)象做為匹配模式對(duì)字符串展開匹配檢查。2016-12-12
SpringBoot實(shí)現(xiàn)Md5對(duì)數(shù)據(jù)庫數(shù)據(jù)加密的示例
本文主要介紹了SpringBoot實(shí)現(xiàn)Md5對(duì)數(shù)據(jù)庫數(shù)據(jù)加密的示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
SpringBoot攔截器執(zhí)行后,Controller層不執(zhí)行的問題及解決
請(qǐng)求攔截器中若調(diào)用getInputStream()讀取流,會(huì)導(dǎo)致Controller層無法獲取請(qǐng)求體,引發(fā)400錯(cuò)誤,解決方案:避免在攔截器中讀取流,或使用緩存(如將流轉(zhuǎn)為字符串)確保數(shù)據(jù)可重復(fù)使用2025-07-07

