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

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

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

MyBaties簡介

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

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

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

MyBatis歷史

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

遷移到Github下載地址。

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

為什么要使用MyBatis

MyBatis是一個半自動化的持久化層框架

JDBC

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

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

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

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

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

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

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

MyBatis-HelloWorld

主要步驟

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

  • 創(chuàng)建對應(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)建對應(yīng)的javaBean對象,重寫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接口的實現(xiàn)類如何工作。這也是我們使用MyBatis時編寫的最多的文件。

<?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)識
    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對象

/**
     * 獲取SqlSessionFactory對象
     * @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對象,一個SqlSession對象代表和數(shù)據(jù)庫的一次會話

public static void test01() throws IOException {
        //1、獲取SqlSessionFactory對象
        SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
        //2、獲取SqlSession對象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //3、獲取接口的實現(xiàn)類對象
        //會為接口自動創(chuàng)建一個代理對象,代理對象去執(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 的實例不是線程安全的,因此是不能被共享的。
  • SqlSession每次使用完成后需要正確關(guān)閉,這個關(guān)閉操作是必須的
  • SqlSession可以直接調(diào)用方法的id進(jìn)行數(shù)據(jù)庫操作,但是我們一般還是推薦使用SqlSession獲取到Dao接口的代理類,執(zhí)行代理對象的方法,可以更安全的進(jìn)行類型檢查操作

總結(jié)

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

相關(guān)文章

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

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

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

    SpringBoot2種單元測試方法解析

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

    Java枚舉類使用Lombok方式

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

最新評論