亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Java Mybatis框架入門基礎教程

2019-11-20 11:32:28
字體:
來源:轉載
供稿:網友

一、Mybatis介紹

MyBatis是一款一流的支持自定義SQL、存儲過程和高級映射的持久化框架。MyBatis幾乎消除了所有的JDBC代碼,也基本不需要手工去 設置參數和獲取檢索結果。MyBatis能夠使用簡單的XML格式或者注解進行來配置,能夠映射基本數據元素、Map接口和POJOs(普通java對象)到數據庫中的記錄。

二、MyBatis工作流程

(1)加載配置并初始化

觸發條件:加載配置文件

配置來源于兩個地方,一處是配置文件,一處是Java代碼的注解,將SQL的配置信息加載成為一個個MappedStatement對象(包括了傳入參數映射配置、執行的SQL語句、結果映射配置),存儲在內存中。

(2)接收調用請求

觸發條件:調用Mybatis提供的API

傳入參數:為SQL的ID和傳入參數對象

處理過程:將請求傳遞給下層的請求處理層進行處理。

(3)處理操作請求 觸發條件:API接口層傳遞請求過來

傳入參數:為SQL的ID和傳入參數對象

處理過程:

(A)根據SQL的ID查找對應的MappedStatement對象。
(B)根據傳入參數對象解析MappedStatement對象,得到最終要執行的SQL和執行傳入參數。
(C)獲取數據庫連接,根據得到的最終SQL語句和執行傳入參數到數據庫執行,并得到執行結果。
(D)根據MappedStatement對象中的結果映射配置對得到的執行結果進行轉換處理,并得到最終的處理結果。
(E)釋放連接資源。

(4)返回處理結果將最終的處理結果返回

orm工具的基本思想

無論是用過的hibernate,mybatis,你都可以法相他們有一個共同點:

  • 從配置文件(通常是XML配置文件中)得到 sessionfactory.
  • 由sessionfactory  產生 session
  • 在session 中完成對數據的增刪改查和事務提交等.
  • 在用完之后關閉session 。
  • 在java 對象和 數據庫之間有做mapping 的配置文件,也通常是xml 文件。

功能架構

Mybatis的功能架構分為三層:

1、API接口層:提供給外部使用的接口API,開發人員通過這些本地API來操縱數據庫。接口層一接收到調用請求就會調用數據處理層來完成具體的數據處理。

2、數據處理層:負責具體的SQL查找、SQL解析、SQL執行和執行結果映射處理等。它主要的目的是根據調用的請求完成一次數據庫操作。

3、基礎支撐層:負責最基礎的功能支撐,包括連接管理、事務管理、配置加載和緩存處理,這些都是共用的東西,將他們抽取出來作為最基礎的組件。為上層的數據處理層提供最基礎的支撐。

多需要添加的驅動包:

下面進行快速入門:

目錄如下:

實體類User

package com.oumyye.model;public class User {  private String id;  private String name;  private int age;  public String getId() {    return id;  }  public void setId(String id) {    this.id = id;  }  public String getName() {    return name;  }  public void setName(String name) {    this.name = name;  }  public int getAge() {    return age;  }  public void setAge(int age) {    this.age = age;  }  @Override  public String toString() {    return "User [id=" + id + ", name=" + name + ", age=" + age + "]";  }}

映射文件UserMapping.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.oumyye.mapping.UserMapping">  <!-- 在select標簽中編寫查詢的SQL語句, 設置select標簽的id屬性為getUser,id屬性值必須是唯一的,不能夠重復  使用parameterType屬性指明查詢時使用的參數類型,resultType屬性指明查詢返回的結果集類型  resultType="com.oumyye.model.User"就表示將查詢結果封裝成一個User類的對象返回  User類就是users表所對應的實體類  -->  <!--     根據id查詢得到一個user對象   -->  <select id="getUser" parameterType="String"     resultType="com.oumyye.model.User">    select * from user where id=#{id}  </select></mapper>

資源文件mybatis.xml

<?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="root" />      </dataSource>    </environment>  </environments>  <mappers><mapper resource="com/oumyye/mapping/userMapping.xml"/>   </mappers></configuration>

測試類:

package test;import java.io.InputStream;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Test;import com.oumyye.model.User;public class Tests {@Testpublic void test(){ String resource = "mybatis.xml";    //使用類加載器加載mybatis的配置文件(它也加載關聯的映射文件)    InputStream is = Tests.class.getClassLoader().getResourceAsStream(resource);    //構建sqlSession的工廠    SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);SqlSession session = sessionFactory.openSession();    /**     * 映射sql的標識字符串,     * com.oumyye.mapping.UserMapping是userMapper.xml文件中mapper標簽的namespace屬性的值,     * getUser是select標簽的id屬性值,通過select標簽的id屬性值就可以找到要執行的SQL     */    String statement = "com.oumyye.mapping.UserMapping.getUser";//映射sql的標識字符串    //執行查詢返回一個唯一user對象的sql    User user = session.selectOne(statement, "1123");    System.out.println(user.toString());}}

結果:

以上就是關于Java Mybatis框架入門基礎教程,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
福利一区福利二区微拍刺激| 亚洲欧美三级伦理| 国产精品黄视频| 欧美最猛性xxxx| 欧美性极品xxxx娇小| 91日本在线视频| 一区二区亚洲欧洲国产日韩| 欧美日韩国产第一页| 福利微拍一区二区| 亚洲国产精品久久久| 欧美日韩美女在线| 欧美丰满少妇xxxx| 久久青草福利网站| 欧美激情视频给我| 欧美丝袜一区二区| 亚洲视频电影图片偷拍一区| 北条麻妃在线一区二区| 欧美丝袜一区二区| 国产精品久久久久久久一区探花| 欧美裸体视频网站| 97视频在线观看视频免费视频| 日本最新高清不卡中文字幕| 国产欧美精品一区二区三区介绍| 国产精品午夜一区二区欲梦| 911国产网站尤物在线观看| 1769国内精品视频在线播放| 一区二区成人精品| 国产精品日日摸夜夜添夜夜av| 国产精品美女久久久久av超清| 亚洲亚裔videos黑人hd| 久久九九热免费视频| 国产精品日本精品| 超在线视频97| 久久精品成人动漫| 最近2019年手机中文字幕| 亚洲视频免费一区| 欧美综合国产精品久久丁香| 久久激情视频久久| 亚洲最大激情中文字幕| 精品亚洲一区二区三区在线播放| 亚洲成人av片| 久久久久久久久久久亚洲| 国产精品日韩在线观看| 国产成人拍精品视频午夜网站| 久久香蕉国产线看观看网| 欧美精品激情在线观看| 亚洲a中文字幕| 日韩欧美一区视频| 国产日韩综合一区二区性色av| 亚洲人成电影在线播放| 久久久久免费视频| 国产精品三级久久久久久电影| 日韩中文视频免费在线观看| 国产精品伦子伦免费视频| 色婷婷av一区二区三区在线观看| 亚洲影院高清在线| 九色成人免费视频| 精品国产欧美一区二区五十路| 亚洲aa在线观看| 久久九九全国免费精品观看| 久久国产精品首页| 久久久噜噜噜久久| 欧美激情乱人伦| 欧美黑人又粗大| 欧美电影免费观看高清| 亚洲国产精品99| 久久久久久有精品国产| 亚洲欧美日韩爽爽影院| 国产精品一区二区三区免费视频| 久久久久久这里只有精品| 久久大大胆人体| 欧美第一页在线| 在线观看国产欧美| 久久久久久久久久久av| 国产精品69av| 亚洲精品丝袜日韩| 97精品久久久| 狠狠爱在线视频一区| 久久久av网站| 亚洲自拍欧美另类| 日韩高清有码在线| 亚洲一级免费视频| 51精品国产黑色丝袜高跟鞋| 亚洲欧美国产日韩天堂区| 国产精品十八以下禁看| 亚洲黄页视频免费观看| 精品无人区乱码1区2区3区在线| 亚洲另类xxxx| 成人中文字幕+乱码+中文字幕| 黑丝美女久久久| 成人福利视频网| 国产精品美女网站| 久久精品国产亚洲精品| 久久久成人的性感天堂| 亚洲午夜精品久久久久久久久久久久| 高清欧美一区二区三区| 亚洲欧美日韩中文在线制服| 亚洲国产精品高清久久久| 日韩欧美福利视频| 国产精品va在线播放| 另类少妇人与禽zozz0性伦| 欧美午夜www高清视频| 国产啪精品视频网站| www.美女亚洲精品| 亚洲一区二区自拍| 亚洲第一区在线观看| 色噜噜亚洲精品中文字幕| 亚洲第一综合天堂另类专| 97在线视频免费看| 在线午夜精品自拍| 美日韩精品视频免费看| 亚洲欧美在线免费观看| 亚洲精品视频久久| 久久99久久亚洲国产| 国产成人精品视频| 日本19禁啪啪免费观看www| 成人激情av在线| 午夜精品蜜臀一区二区三区免费| 亚洲欧美日本伦理| 欧美日韩免费区域视频在线观看| 在线播放国产一区二区三区| 亚洲国产成人在线视频| 国产亚洲精品久久久久动| 正在播放国产一区| 亚洲国产高潮在线观看| 亚洲欧美制服中文字幕| 日韩欧美a级成人黄色| 久久久免费电影| 国产精品免费观看在线| 91国产高清在线| 国产精品v片在线观看不卡| 亚洲国产日韩精品在线| 国产精品尤物福利片在线观看| 久久视频在线播放| 中文字幕日本精品| 免费不卡欧美自拍视频| 韩国三级日本三级少妇99| 欧美日韩精品在线观看| 国产丝袜一区二区三区免费视频| 亚洲美女又黄又爽在线观看| 亚洲人精品午夜在线观看| 正在播放欧美一区| 久久久久久久久久久久av| 亚洲国产精久久久久久久| 九色精品免费永久在线| 日韩亚洲第一页| 欧美国产精品日韩| 91黑丝高跟在线| 欧美精品电影免费在线观看| 亚洲欧美制服中文字幕| 国产成人精品久久二区二区| 欧美黄色小视频| 国产日韩欧美视频在线| 欧美一区在线直播| 日韩动漫免费观看电视剧高清| 欧美国产日韩精品| 国产精品第2页| 亚洲精品视频二区| 日本一区二区在线免费播放| 4p变态网欧美系列| 69**夜色精品国产69乱| 毛片精品免费在线观看| 久久九九全国免费精品观看| 国产丝袜一区二区三区|