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

Mybatis超詳細(xì)講解構(gòu)建SQL方法

 更新時(shí)間:2022年07月05日 11:15:16   作者:流楚丶格念  
這篇文章主要為大家詳細(xì)介紹了Mybatis構(gòu)建SQL,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

1 SQL 構(gòu)建對(duì)象介紹

1.1.1 介紹

我們之前通過注解開發(fā)時(shí),相關(guān) SQL 語句都是自己直接拼寫的。一些關(guān)鍵字寫起來比較麻煩、而且容易出錯(cuò)。

MyBatis 給我們提供了 org.apache.ibatis.jdbc.SQL 功能類,專門用于構(gòu)建 SQL 語句

1.1.2 實(shí)現(xiàn)準(zhǔn)備

編寫指定調(diào)用方法

package com.yyl.sql;
import com.yyl.bean.Student;
import org.apache.ibatis.jdbc.SQL;
public class ReturnSql {
    //定義方法,返回查詢的sql語句
    public String getSelectAll() {
        return new SQL() {
            {
                SELECT("*");
                FROM("student");
            }
        }.toString();
    }
    //定義方法,返回新增的sql語句
    public String getInsert(Student stu) {
        return new SQL() {
            {
                INSERT_INTO("student");
                INTO_VALUES("#{id},#{name},#{age}");
            }
        }.toString();
    }
    //定義方法,返回修改的sql語句
    public String getUpdate(Student stu) {
        return new SQL() {
            {
                UPDATE("student");
                SET("name=#{name}","age=#{age}");
                WHERE("id=#{id}");
            }
        }.toString();
    }
    //定義方法,返回刪除的sql語句
    public String getDelete(Integer id) {
        return new SQL() {
            {
                DELETE_FROM("student");
                WHERE("id=#{id}");
            }
        }.toString();
    }
}

這是嘛?。???

這就是Mybatis進(jìn)行構(gòu)建時(shí)候給你的構(gòu)建SQL對(duì)象,就例如下面咱對(duì)new 處理的這個(gè)SQL對(duì)象進(jìn)行測(cè)試:

public static void main(String[] args) {
    String sql = getSql();
    System.out.println(sql);
}
//定義方法,獲取查詢student表的sql語句
/*public static String getSql() {
    String sql = "SELECT * FROM student";
    return sql;
}*/
public static String getSql() {
    String sql = new SQL(){
        {
            SELECT("*");
            FROM("student");
        }
    }.toString();
    return sql;
}

運(yùn)行結(jié)果如下:

就是返回sql語句

2 查詢功能的實(shí)現(xiàn)

定義功能類并提供獲取查詢的 SQL 語句的方法。

例如下面的語句把之前的@Select換為了現(xiàn)在的@SelectProvider

//查詢?nèi)?
//@Select("SELECT * FROM student")
@SelectProvider(type = ReturnSql.class , method = "getSelectAll")
public abstract List<Student> selectAll();

屬性說明:

屬性說明
@SelectProvider生成查詢用的 SQL 語句注解。
type 屬性生成 SQL 語句功能類對(duì)象
method 屬性指定調(diào)用方法

編寫測(cè)試函數(shù)

@Test
public void selectAll() throws Exception{
    //1.加載核心配置文件
    InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
    //2.獲取SqlSession工廠對(duì)象
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().b
    //3.通過工廠對(duì)象獲取SqlSession對(duì)象
    SqlSession sqlSession = sqlSessionFactory.openSession(true);
    //4.獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
    StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
    //5.調(diào)用實(shí)現(xiàn)類對(duì)象中的方法,接收結(jié)果
    List<Student> list = mapper.selectAll();
    //6.處理結(jié)果
    for (Student student : list) {
        System.out.println(student);
    }
    //7.釋放資源
    sqlSession.close();
    is.close();
}

運(yùn)行結(jié)果如下:

3 新增功能的實(shí)現(xiàn)

定義功能類并提供獲取新增的 SQL 語句的方法。

//新增功能
//@Insert("INSERT INTO student VALUES (#{id},#{name},#{age})")
@InsertProvider(type = ReturnSql.class , method = "getInsert")
public abstract Integer insert(Student stu);

屬性說明:

屬性說明
@InsertProvider生成新增用的 SQL 語句注解。
type 屬性生成 SQL 語句功能類對(duì)象
method 屬性指定調(diào)用方法

編寫測(cè)試函數(shù):

@Test
public void insert() throws Exception{
    //1.加載核心配置文件
    InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
    //2.獲取SqlSession工廠對(duì)象
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
    //3.通過工廠對(duì)象獲取SqlSession對(duì)象
    SqlSession sqlSession = sqlSessionFactory.openSession(true);
    //4.獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
    StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
    //5.調(diào)用實(shí)現(xiàn)類對(duì)象中的方法,接收結(jié)果
    Student stu = new Student(4,"趙六",26);
    Integer result = mapper.insert(stu);
    //6.處理結(jié)果
    System.out.println(result);
    //7.釋放資源
    sqlSession.close();
    is.close();
}

運(yùn)行效果如下:

4 修改功能的實(shí)現(xiàn)

定義功能類并提供獲取修改的 SQL 語句的方法。

//修改功能
//@Update("UPDATE student SET name=#{name},ag
@UpdateProvider(type = ReturnSql.class , meth
public abstract Integer update(Student stu);

屬性說明:

屬性說明
@UpdateProvider生成修改用的 SQL 語句注解。
type 屬性生成 SQL 語句功能類對(duì)象
method 屬性指定調(diào)用方法

編寫測(cè)試函數(shù):

@Test
public void update() throws Exception{
    //1.加載核心配置文件
    InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
    //2.獲取SqlSession工廠對(duì)象
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
    //3.通過工廠對(duì)象獲取SqlSession對(duì)象
    SqlSession sqlSession = sqlSessionFactory.openSession(true);
    //4.獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
    StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
    //5.調(diào)用實(shí)現(xiàn)類對(duì)象中的方法,接收結(jié)果
    Student stu = new Student(7,"趙六",36);
    Integer result = mapper.update(stu);
    //6.處理結(jié)果
    System.out.println(result);
    //7.釋放資源
    sqlSession.close();
    is.close();
}

運(yùn)行效果如下:

5 刪除功能的實(shí)現(xiàn)

定義功能類并提供獲取刪除的 SQL 語句的方法。

//刪除功能
//@Delete("DELETE FROM student WHERE id=#{id}")
@DeleteProvider(type = ReturnSql.class , method
public abstract Integer delete(Integer id);

屬性說明:

屬性說明
@DeleteProvider生成刪除用的 SQL 語句注解。
type 屬性生成 SQL 語句功能類對(duì)象
method 屬性指定調(diào)用方法

編寫測(cè)試函數(shù):

@Test
public void delete() throws Exception{
    //1.加載核心配置文件
    InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
    //2.獲取SqlSession工廠對(duì)象
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
    //3.通過工廠對(duì)象獲取SqlSession對(duì)象
    SqlSession sqlSession = sqlSessionFactory.openSession(true);
    //4.獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
    StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
    //5.調(diào)用實(shí)現(xiàn)類對(duì)象中的方法,接收結(jié)果
    Integer result = mapper.delete(7);
    //6.處理結(jié)果
    System.out.println(result);
    //7.釋放資源
    sqlSession.close();
    is.close();
}

運(yùn)行效果如下:

到此這篇關(guān)于Mybatis超詳細(xì)講解構(gòu)建SQL方法的文章就介紹到這了,更多相關(guān)Mybatis構(gòu)建SQL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java日期格式化SimpleDateFormat的使用詳解

    java日期格式化SimpleDateFormat的使用詳解

    這篇文章主要介紹了java SimpleDateFormat使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • TransmittableThreadLocal通過javaAgent實(shí)現(xiàn)線程傳遞并支持ForkJoin

    TransmittableThreadLocal通過javaAgent實(shí)現(xiàn)線程傳遞并支持ForkJoin

    這篇文章主要介紹了TransmittableThreadLocal通過javaAgent實(shí)現(xiàn)線程傳遞并支持ForkJoin詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Java注解使用及原理解析

    Java注解使用及原理解析

    這篇文章主要介紹了Java注解使用及原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 詳解Java爬蟲利器Jsoup

    詳解Java爬蟲利器Jsoup

    Jsoup是一款Java語言開發(fā)的HTML解析器,用于解析HTML文檔以及對(duì)HTML文檔進(jìn)行操作,處理等,本文就將詳細(xì)給大家介紹一下Java中的爬蟲利器Jsoup,感興趣的同學(xué)可以參考一下
    2023-06-06
  • SpringBoot定時(shí)任務(wù)參數(shù)運(yùn)行代碼實(shí)例解析

    SpringBoot定時(shí)任務(wù)參數(shù)運(yùn)行代碼實(shí)例解析

    這篇文章主要介紹了SpringBoot定時(shí)任務(wù)運(yùn)行代碼實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • SpringBoot如何統(tǒng)一配置bean的別名

    SpringBoot如何統(tǒng)一配置bean的別名

    這篇文章主要介紹了SpringBoot如何統(tǒng)一配置bean的別名,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • java參數(shù)傳值代碼舉例

    java參數(shù)傳值代碼舉例

    在編程中往方法中傳遞參數(shù)的方法往往有兩種,一種是值傳遞,一種是引用傳遞,而在java中所有的參數(shù)傳遞全部都是值傳遞,這篇文章主要給大家介紹了關(guān)于java參數(shù)傳值的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • Struts2相關(guān)的面試題整理分享

    Struts2相關(guān)的面試題整理分享

    這篇文章主要給大家總結(jié)整理了關(guān)于Struts2相關(guān)的面試題,文中先詳細(xì)介紹了關(guān)于struts2的工作原理、工作流程、攔截器和過濾器的區(qū)別以及什么要使用Struts2,然后分享了總結(jié)的一些關(guān)于Struts2面試的一些問題,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-11-11
  • 解析阿里GTS開源版本fescar分布式事務(wù)

    解析阿里GTS開源版本fescar分布式事務(wù)

    這篇文章主要為大家介紹解析阿里GTS開源版本fescar分布式事務(wù)的原理及使用說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多進(jìn)步
    2022-02-02
  • SpringBoot參數(shù)校驗(yàn)的方法總結(jié)

    SpringBoot參數(shù)校驗(yàn)的方法總結(jié)

    今天帶大家學(xué)習(xí)SpringBoot參數(shù)校驗(yàn)的方法,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-05-05

最新評(píng)論