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

MyBatis基本實(shí)現(xiàn)過程

 更新時(shí)間:2021年07月09日 10:33:36   作者:程序dunk  
這篇文章主要介紹了Spring整合mybatis實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

MyBaties簡介

MyBatis是支持定制化SQL、存儲(chǔ)過程以及高級(jí)映射的優(yōu)秀的持久層框架。

MyBatis避免了幾乎所有的JDBC代碼和手動(dòng)設(shè)置參數(shù)以及獲取結(jié)果集

MyBatis可以使用簡單的XML或注解用于配置和原始映射,將接口和JavaPOJO(Plain Old Java Object,普通的Java對(duì)象)映射成數(shù)據(jù)庫中的記錄

MyBatis歷史

原是Apache的一個(gè)開源項(xiàng)目iBatis, 2010年6月這個(gè)項(xiàng)目由Apache Software Foundation 遷移到了Google Code,隨著開發(fā)團(tuán)隊(duì)轉(zhuǎn)投Google Code旗下, iBatis3.x正式更名為MyBatis ,代碼于2013年11月

遷移到Github下載地址

iBatis一詞來源于“internet”和“abatis”的組合,是一個(gè)基于Java的持久層框架。 iBatis提供的持久層框架包括SQL Maps和Data Access Objects(DAO)

為什么要使用MyBatis

MyBatis是一個(gè)半自動(dòng)化的持久化層框架

JDBC

JDBC -> Dbutils(QueryRunner) -> JdbcTemplate:工具

功能簡單;sql語句編寫在java代碼里面;硬編碼高耦合的方式

Hibernate:全自動(dòng)全映射ORM(Object Relation Mapping)框架;旨在消除sql,HQL

希望:sql語句交給我們開發(fā)人員編寫,希望sql不失去靈活性;

  • SQL夾在Java代碼塊里,耦合度高導(dǎo)致硬編碼內(nèi)傷
  • 維護(hù)不易且實(shí)際開發(fā)需求中sql是有變化,頻繁修改的情況多見 • Hibernate和JPA
  • 長難復(fù)雜SQL,對(duì)于Hibernate而言處理也不容易
  • 內(nèi)部自動(dòng)生產(chǎn)的SQL,不容易做特殊優(yōu)化。
  • 基于全映射的全自動(dòng)框架,大量字段的POJO進(jìn)行部分映射時(shí)比較困難。

導(dǎo)致數(shù)據(jù)庫性能下降。

  • 對(duì)開發(fā)人員而言,核心sql還是需要自己優(yōu)化
  • sql和java編碼分開,功能邊界清晰,一個(gè)專注業(yè)務(wù)、一個(gè)專注數(shù)據(jù)

MyBatis-HelloWorld

主要步驟

HelloWorld簡單版 – 創(chuàng)建一張測試表

  • 創(chuàng)建對(duì)應(yīng)的javaBean
  • 創(chuàng)建mybatis配置文件,sql映射文件
  • 測試

首先在數(shù)據(jù)庫中創(chuàng)建一張Employee表隨便插入一條數(shù)據(jù)以便測試

CREATE TABLE `tbl_employee` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `last_name` varchar(255) DEFAULT NULL,
  `gender` char(1) DEFAULT NULL,
  `email` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

在idea中導(dǎo)包

創(chuàng)建對(duì)應(yīng)的javaBean對(duì)象,重寫toString方法,方便后面輸出

public class Employee {
    private int id;
    private String last_name;
    private String gender;
    private String email;
    public Employee() {
    }
    public Employee(int id, String laseName, String gender, String email) {
        this.id = id;
        this.last_name = laseName;
        this.gender = gender;
        this.email = email;
    }
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getLaseName() {
        return last_name;
    }
    public void setLaseName(String laseName) {
        this.last_name = laseName;
    }
    public String getGender() {
        return gender;
    }
    public void setGender(String gender) {
        this.gender = gender;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
    @Override
    public String toString() {
        return "Employee{" +
                "id=" + id +
                ", laseName='" + last_name + '\'' +
                ", gender='" + gender + '\'' +
                ", email='" + email + '\'' +
                '}';
    }
}

創(chuàng)建Mapper接口

import school.xauat.mybatis.bean.Employee;
public interface EmployeeMapper {
    public Employee getEmpById(Integer id);
}

創(chuàng)建MyBatis全局配置文件

– MyBatis 的全局配置文件包含了影響 MyBatis 行為甚深的設(shè)置(settings)和屬性(properties)信息、如數(shù)據(jù)庫連接池信息等。指導(dǎo)著MyBatis進(jìn)行工作。我們可以參照官方文件的配置示例。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>
                <property name="username" value="root"/>
                <property name="password" value="***"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="EmployeeMapper.xml"/>
    </mappers>
</configuration>

創(chuàng)建SQL映射文件

映射文件的作用就相當(dāng)于是定義Dao接口的實(shí)現(xiàn)類如何工作。這也是我們使用MyBatis時(shí)編寫的最多的文件。

<?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="school.xauat.mybatis.dao.EmployeeMapper">
    <!--
    namespace:名稱空間;指定為接口的全類名
    id:唯一標(biāo)識(shí)
    resultType:返回值類型
    #{id}:從傳遞過來的參數(shù)中取出id值
    -->
    <select id="getEmpById" resultType="school.xauat.mybatis.bean.Employee">
        select * from tbl_employee where id = #{id}
    </select>
</mapper>

測試

1、根據(jù)全局配置文件,利用SqlSessionFactoryBuilder創(chuàng)建SqlSessionFactory對(duì)象

/**
     * 獲取SqlSessionFactory對(duì)象
     * @return
     * @throws IOException
     */
    public static SqlSessionFactory getSqlSessionFactory() throws IOException{
        String resource = "mybatis-config.xml";
        InputStream  inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        return sqlSessionFactory;
    }

2、使用SqlSessionFactory獲取SqlSession對(duì)象,一個(gè)SqlSession對(duì)象代表和數(shù)據(jù)庫的一次會(huì)話

public static void test01() throws IOException {
        //1、獲取SqlSessionFactory對(duì)象
        SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
        //2、獲取SqlSession對(duì)象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //3、獲取接口的實(shí)現(xiàn)類對(duì)象
        //會(huì)為接口自動(dòng)創(chuàng)建一個(gè)代理對(duì)象,代理對(duì)象去執(zhí)行增刪改查
        EmployeeMapper mapper = sqlSession.getMapper(EmployeeMapper.class);
        Employee employee = mapper.getEmpById(1);
        System.out.println(mapper.getClass());
        System.out.println(employee);
        sqlSession.close();
    }

調(diào)用test01

注意SqlSession

  • SqlSession 的實(shí)例不是線程安全的,因此是不能被共享的。
  • SqlSession每次使用完成后需要正確關(guān)閉,這個(gè)關(guān)閉操作是必須的
  • SqlSession可以直接調(diào)用方法的id進(jìn)行數(shù)據(jù)庫操作,但是我們一般還是推薦使用SqlSession獲取到Dao接口的代理類,執(zhí)行代理對(duì)象的方法,可以更安全的進(jìn)行類型檢查操作

總結(jié)

本篇文章就到這里了,希望能給你帶來幫助,也希望你能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • springmvc處理模型數(shù)據(jù)Map過程解析

    springmvc處理模型數(shù)據(jù)Map過程解析

    這篇文章主要介紹了springmvc處理模型數(shù)據(jù)Map過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • SpringBoot2種單元測試方法解析

    SpringBoot2種單元測試方法解析

    這篇文章主要介紹了SpringBoot2種單元測試方法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • Java枚舉類使用Lombok方式

    Java枚舉類使用Lombok方式

    這篇文章主要介紹了Java枚舉類使用Lombok方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Spring security認(rèn)證兩類用戶代碼實(shí)例

    Spring security認(rèn)證兩類用戶代碼實(shí)例

    這篇文章主要介紹了Spring security認(rèn)證兩類用戶代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • IDEA實(shí)現(xiàn) springmvc的簡單注冊(cè)登錄功能的示例代碼

    IDEA實(shí)現(xiàn) springmvc的簡單注冊(cè)登錄功能的示例代碼

    這篇文章主要介紹了IDEA實(shí)現(xiàn) springmvc的簡單注冊(cè)登錄功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • SonarQube安裝、配置與使用教程圖解

    SonarQube安裝、配置與使用教程圖解

    這篇文章主要介紹了SonarQube安裝、配置與使用教程圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Java 獲取當(dāng)前時(shí)間及實(shí)現(xiàn)時(shí)間倒計(jì)時(shí)功能【推薦】

    Java 獲取當(dāng)前時(shí)間及實(shí)現(xiàn)時(shí)間倒計(jì)時(shí)功能【推薦】

    這篇文章主要介紹了Java 獲取當(dāng)前時(shí)間及實(shí)現(xiàn)時(shí)間倒計(jì)時(shí)功能 ,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • Spring?Security+JWT簡述(附源碼)

    Spring?Security+JWT簡述(附源碼)

    SpringSecurity是一個(gè)強(qiáng)大的可高度定制的認(rèn)證和授權(quán)框架,對(duì)于Spring應(yīng)用來說它是一套Web安全標(biāo)準(zhǔn),下面這篇文章主要給大家介紹了關(guān)于Spring?Security+JWT簡述的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • Java實(shí)現(xiàn)一個(gè)簡單的線程池代碼示例

    Java實(shí)現(xiàn)一個(gè)簡單的線程池代碼示例

    線程池是管理線程的一個(gè)池子,通過阻塞隊(duì)列管理任務(wù),主要參數(shù)包括corePoolSize、maximumPoolSize、keepAliveTime等,這篇文章主要介紹了Java實(shí)現(xiàn)一個(gè)簡單的線程池的相關(guān)資料,需要的朋友可以參考下
    2024-09-09
  • IDEA設(shè)置Tab選項(xiàng)卡快速的操作

    IDEA設(shè)置Tab選項(xiàng)卡快速的操作

    這篇文章主要介紹了IDEA設(shè)置Tab選項(xiàng)卡快速的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02

最新評(píng)論