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

MyBatis代理Dao方式的增刪改查的實(shí)現(xiàn)小結(jié)

 更新時(shí)間:2025年11月05日 09:28:49   作者:222you  
本文主要介紹了MyBatis代理Dao方式的增刪改查的實(shí)現(xiàn)小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

首先創(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)與停止腳本的方法

    這篇文章主要介紹了Centos下SpringBoot項(xiàng)目啟動(dòng)與停止腳本的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • SpringBoot使用Guava實(shí)現(xiàn)日志脫敏的示例代碼

    SpringBoot使用Guava實(shí)現(xiàn)日志脫敏的示例代碼

    本文主要介紹了SpringBoot使用Guava實(shí)現(xiàn)日志脫敏的示例代碼,使用Guava中的Strings、Maps和CharMatcher類來進(jìn)行日志脫敏,保護(hù)敏感數(shù)據(jù)的安全,感興趣的可以了解一下
    2024-01-01
  • Java8處理List的雙層循環(huán)問題

    Java8處理List的雙層循環(huán)問題

    這篇文章主要介紹了Java8處理List的雙層循環(huán)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • SpringCloud?服務(wù)注冊(cè)中的nacos實(shí)現(xiàn)過程

    SpringCloud?服務(wù)注冊(cè)中的nacos實(shí)現(xiàn)過程

    這篇文章主要介紹了SpringCloud?服務(wù)注冊(cè)之nacos實(shí)現(xiàn)過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • 深入理解Java中1是true0是false

    深入理解Java中1是true0是false

    Java中,1可以被看作是true,0可以被看作是false,本文就來進(jìn)行詳細(xì)的講解,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • 使用Java讀取本地文件并轉(zhuǎn)換為MultipartFile對(duì)象的方法

    使用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ú)占模式)

    Java并發(fā)系列之AbstractQueuedSynchronizer源碼分析(獨(dú)占模式)

    這篇文章主要為大家詳細(xì)介紹了Java并發(fā)系列之AbstractQueuedSynchronizer源碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • 詳解Java正則表達(dá)式中Pattern類和Matcher類

    詳解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ù)加密的示例

    本文主要介紹了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í)行的問題及解決

    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

最新評(píng)論