精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Java Mybatis 框架入門教程

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

一、Mybatis介紹

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

二、MyBatis工作流程

(1)加載配置并初始化

觸發(fā)條件:加載配置文件

配置來源于兩個(gè)地方,一處是配置文件,一處是Java代碼的注解,將SQL的配置信息加載成為一個(gè)個(gè)MappedStatement對(duì)象(包括了傳入?yún)?shù)映射配置、執(zhí)行的SQL語句、結(jié)果映射配置),存儲(chǔ)在內(nèi)存中。

(2)接收調(diào)用請(qǐng)求

觸發(fā)條件:調(diào)用Mybatis提供的API

傳入?yún)?shù):為SQL的ID和傳入?yún)?shù)對(duì)象

處理過程:將請(qǐng)求傳遞給下層的請(qǐng)求處理層進(jìn)行處理。

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

傳入?yún)?shù):為SQL的ID和傳入?yún)?shù)對(duì)象

處理過程:

(A)根據(jù)SQL的ID查找對(duì)應(yīng)的MappedStatement對(duì)象。
(B)根據(jù)傳入?yún)?shù)對(duì)象解析MappedStatement對(duì)象,得到最終要執(zhí)行的SQL和執(zhí)行傳入?yún)?shù)。
(C)獲取數(shù)據(jù)庫連接,根據(jù)得到的最終SQL語句和執(zhí)行傳入?yún)?shù)到數(shù)據(jù)庫執(zhí)行,并得到執(zhí)行結(jié)果。
(D)根據(jù)MappedStatement對(duì)象中的結(jié)果映射配置對(duì)得到的執(zhí)行結(jié)果進(jìn)行轉(zhuǎn)換處理,并得到最終的處理結(jié)果。
(E)釋放連接資源。

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

orm工具的基本思想

無論是用過的hibernate,mybatis,你都可以法相他們有一個(gè)共同點(diǎn):

  •  從配置文件(通常是XML配置文件中)得到 sessionfactory.

  •  由sessionfactory  產(chǎn)生 session

  •  在session 中完成對(duì)數(shù)據(jù)的增刪改查和事務(wù)提交等.

  •  在用完之后關(guān)閉session 。

  •  在java 對(duì)象和 數(shù)據(jù)庫之間有做mapping 的配置文件,也通常是xml 文件。

功能架構(gòu)

Java框架篇---Mybatis 入門

Mybatis的功能架構(gòu)分為三層:

  1. API接口層:提供給外部使用的接口API,開發(fā)人員通過這些本地API來操縱數(shù)據(jù)庫。接口層一接收到調(diào)用請(qǐng)求就會(huì)調(diào)用數(shù)據(jù)處理層來完成具體的數(shù)據(jù)處理。

  2. 數(shù)據(jù)處理層:負(fù)責(zé)具體的SQL查找、SQL解析、SQL執(zhí)行和執(zhí)行結(jié)果映射處理等。它主要的目的是根據(jù)調(diào)用的請(qǐng)求完成一次數(shù)據(jù)庫操作。

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

多需要添加的驅(qū)動(dòng)包:

Java框架篇---Mybatis 入門

下面進(jìn)行快速入門:

目錄如下:

Java框架篇---Mybatis 入門

實(shí)體類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標(biāo)簽中編寫查詢的SQL語句, 設(shè)置select標(biāo)簽的id屬性為getUser,id屬性值必須是唯一的,不能夠重復(fù)
    使用parameterType屬性指明查詢時(shí)使用的參數(shù)類型,resultType屬性指明查詢返回的結(jié)果集類型
    resultType="com.oumyye.model.User"就表示將查詢結(jié)果封裝成一個(gè)User類的對(duì)象返回
    User類就是users表所對(duì)應(yīng)的實(shí)體類
    -->
    <!--
        根據(jù)id查詢得到一個(gè)user對(duì)象
     -->
    <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" />
            <!-- 配置數(shù)據(jù)庫連接信息 -->
            <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>

測(cè)試類:

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 {
@Test
public void test(){
  String resource = "mybatis.xml";
        //使用類加載器加載mybatis的配置文件(它也加載關(guān)聯(lián)的映射文件)
        InputStream is = Tests.class.getClassLoader().getResourceAsStream(resource);
        //構(gòu)建sqlSession的工廠
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);

        SqlSession session = sessionFactory.openSession();
        /**
         * 映射sql的標(biāo)識(shí)字符串,
         * com.oumyye.mapping.UserMapping是userMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
         * getUser是select標(biāo)簽的id屬性值,通過select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
         */
        String statement = "com.oumyye.mapping.UserMapping.getUser";//映射sql的標(biāo)識(shí)字符串
        //執(zhí)行查詢返回一個(gè)唯一user對(duì)象的sql
        User user = session.selectOne(statement, "1123");
        System.out.println(user.toString());
}
}

結(jié)果:

Java框架篇---Mybatis 入門

責(zé)任編輯:王雪燕 來源: 偶my耶的博客
相關(guān)推薦

2012-07-17 09:13:14

Scrapy

2009-07-08 15:12:48

Java Servle

2009-06-18 09:29:44

Spring Web

2012-05-25 15:35:43

JMSJava

2014-05-26 15:35:55

Web組件Web Compone

2010-08-03 13:06:15

Flex Builde

2013-08-29 14:12:52

Storm分布式實(shí)時(shí)計(jì)算

2016-03-18 11:19:57

ios9replaykit入門

2017-09-16 17:45:32

數(shù)據(jù)采集Scrapy爬蟲

2020-02-21 08:18:58

JavaScala編程語言

2018-03-22 14:59:13

Docker入門容器

2010-06-18 16:56:50

UML建模語言

2011-09-02 10:59:10

jQuery Mobi

2013-06-24 13:38:34

HTML5 DataList

2010-07-20 16:19:54

Perl

2010-06-13 09:45:35

Widget開發(fā)

2013-08-29 14:28:09

StormHadoop

2010-05-21 12:50:45

Subversion快

2024-11-12 15:46:37

2010-08-03 14:37:30

Flex入門教程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

天堂…中文在线最新版在线| 国产美女直播视频一区| 国产亚洲精品成人a| av资源在线看片| 久久理论电影网| 国产在线拍偷自揄拍精品| 欧美一区二区三区爽爽爽| 成人福利一区| 欧美性生活大片视频| 国产女主播av| 免费a在线观看| 国产米奇在线777精品观看| 97国产精品视频| 国产视频精品免费| 久9re热视频这里只有精品| 欧美在线免费观看视频| 精品一区二区三区无码视频| 国产视频精选在线| 国产风韵犹存在线视精品| 日本高清+成人网在线观看| 午夜爽爽爽男女免费观看| 欧美成人专区| 宅男噜噜噜66一区二区66| 可以免费观看av毛片| bestiality新另类大全| 国产亚洲一本大道中文在线| 国产精品一区二区a| 亚洲一区中文字幕在线| 国产欧美日韩综合一区在线播放| 久久影视电视剧免费网站| 人人人妻人人澡人人爽欧美一区| 亚洲五码在线| 91精品国产全国免费观看| 日本va中文字幕| 麻豆国产在线| 亚洲电影一级黄| 四虎免费在线观看视频| 搞黄视频免费在线观看| 久久婷婷国产综合精品青草| 99国精产品一二二线| aaa在线视频| 亚洲自拍另类| 国产69精品久久久| 久久久久久久久艹| 亚洲蜜桃视频| 久久伊人色综合| 免费高清在线观看电视| 天天射综合网视频| 最近2019好看的中文字幕免费| 国产三级视频网站| 色橹橹欧美在线观看视频高清| 欧美刺激午夜性久久久久久久| 超碰人人草人人| 亚洲热av色在线播放| 欧美日韩一区二区在线视频| 国产一二三四在线视频| 国产经典一区| 欧美丝袜丝交足nylons| 亚洲精品自拍网| 日韩黄色在线| 91精品国产综合久久香蕉的特点| 男生操女生视频在线观看| yy6080久久伦理一区二区| 欧美亚洲国产一区二区三区| 欧美婷婷精品激情| 巨大黑人极品videos精品| 欧美日韩中字一区| 热久久久久久久久| 欧美中文高清| 亚洲福利在线看| 精品无码在线视频| 国产精品午夜一区二区三区| 国产亚洲视频在线| 男人晚上看的视频| 午夜天堂精品久久久久| 久久久噜噜噜久久| www.国产高清| 久久精品999| 亚洲字幕在线观看| 人妻视频一区二区三区| 久久午夜电影网| 亚洲 日韩 国产第一区| 久操视频在线观看| 亚洲福利视频导航| 免费裸体美女网站| gogo大尺度成人免费视频| 日韩欧美一区中文| 亚洲专区区免费| 日韩一区电影| 久久久免费电影| 欧美男人天堂网| 国产精品白丝jk黑袜喷水| 精品网站在线看| 中文字幕在线免费| 亚洲777理论| 日日碰狠狠躁久久躁婷婷| 视频91a欧美| 亚洲激情视频网| 国产18无套直看片| 影音先锋亚洲一区| 最新精品国偷自产在线| 日韩欧美一区二区免费| 女~淫辱の触手3d动漫| 五月天激情综合网| 2019中文字幕免费视频| 在线观看免费视频a| 丁香啪啪综合成人亚洲小说 | www成人免费| 超碰国产一区| 日韩欧美一区在线| 337人体粉嫩噜噜噜| 亚洲欧洲一区| 成人女保姆的销魂服务| 欧美老女人性开放| 一区二区三区91| 国产色视频在线播放| 久久中文字幕导航| 欧美成人免费播放| 国产女优在线播放| 久久伊人中文字幕| 无码人妻少妇伦在线电影| 亚洲人体在线| 一区二区成人av| 久久久精品福利| 成人综合婷婷国产精品久久蜜臀| 最近看过的日韩成人| 韩国三级一区| 日韩av网站导航| 妺妺窝人体色www在线下载| 蜜桃视频免费观看一区| 欧美不卡在线一区二区三区| aaa在线播放视频| 日韩一区二区三区在线| 亚洲欧美综合7777色婷婷| 性伦欧美刺激片在线观看| 99视频在线| 色图在线观看| 日韩一区二区在线看片| 91嫩草丨国产丨精品| 日本视频免费一区| 欧美日韩在线播放一区二区| 久久久男人天堂| 亚洲第一免费播放区| 69av视频在线| 国产91富婆露脸刺激对白| 女同性恋一区二区| 成人自拍视频| 欧美xxxx综合视频| 精品国产九九九| 亚洲精品久久嫩草网站秘色| 交换做爰国语对白| 久久久久久美女精品| 成人福利视频在线观看| 麻豆tv免费在线观看| 欧美精品一卡两卡| 久久久久亚洲av片无码| 国产一区福利在线| 免费日韩在线观看| 国产精品超碰| 欧美性资源免费| 韩国三级在线观看久| 欧美亚洲国产一区二区三区va| 91精品国自产在线| 久久99久久99小草精品免视看| 亚洲国产精品女人| 91蝌蚪精品视频| 97精品国产91久久久久久| 外国精品视频在线观看| 欧美日韩国产在线| 亚洲久久久久久久| 麻豆精品精品国产自在97香蕉| 一区二区三区免费看| 日韩成人在线看| 97国产真实伦对白精彩视频8| 欧美91精品久久久久国产性生爱| 欧美午夜宅男影院| 青青草激情视频| www.99精品| 精品久久久噜噜噜噜久久图片| 日韩av二区| 51精品国产人成在线观看| 97人人在线视频| 国产亚洲精品va在线观看| 在线观看中文字幕2021| 亚洲一区二区精品久久av| 特级西西人体wwwww| 青青草97国产精品免费观看| 肉大捧一出免费观看网站在线播放 | 国产精品成人av| 国产乱码一区| 丁香久久综合| 高清欧美性猛交| 在线视频二区| 亚洲精品www| 97精品久久人人爽人人爽| 亚洲电影激情视频网站| 人人艹在线视频| 成人av高清在线| 中文av字幕在线观看| 亚洲乱码久久| 特色特色大片在线| 一区三区在线欧| 91精品久久香蕉国产线看观看| 亚洲黄色免费av| 欧美日本高清一区| 国产爆初菊在线观看免费视频网站 | 九色精品91| av电影成人| 国产第一亚洲| 青青草原成人在线视频| 一区二区三区伦理| 中文字幕国产精品久久| 亚洲人视频在线观看| 日韩一卡二卡三卡四卡| 中文在线资源天堂| 欧美日韩亚洲激情| 久久久久性色av无码一区二区| 中文字幕精品—区二区四季| 中文字幕免费高清视频| 国产真实乱偷精品视频免| 99久久久无码国产精品6| 午夜激情一区| 在线成人av电影| 精品高清在线| 久久久久久久久久久一区| 999久久久精品一区二区| 成人黄色影片在线| 国产亚洲精彩久久| 国产999在线| 在线免费看h| 高清欧美性猛交| 国产精品—色呦呦| 欧美精品九九久久| 伊人影院在线视频| 久久综合久久美利坚合众国| 免费网站看v片在线a| 深夜精品寂寞黄网站在线观看| 欧美成人片在线| 亚洲欧美综合另类中字| 日韩在线免费看| 日韩经典中文字幕在线观看| 熟妇人妻中文av无码| 亚洲高清久久网| 色偷偷在线观看| 亚洲福利视频在线| 无码国产色欲xxxx视频 | 精品av中文字幕在线毛片| 日韩精品视频在线观看网址| 亚洲国产精品suv| 欧美电视剧在线看免费| 六月丁香综合网| 亚洲成色777777女色窝| 色欲av伊人久久大香线蕉影院| 亚洲第一页在线| 视频一区二区免费| 国产视频亚洲视频| 美女毛片在线看| 在线性视频日韩欧美| 天堂资源在线中文| 精品国产一区久久久| 91一区二区三区在线| 欧美激情精品久久久久久大尺度| 2019中文字幕在线电影免费| 性金发美女69hd大尺寸| 午夜无码国产理论在线| 国产美女直播视频一区| 日韩精品一区国产| 国产一区二区免费在线观看| 日本一道高清一区二区三区| 日本三级中国三级99人妇网站| 精品日韩毛片| 国产av不卡一区二区| 精品91久久久久| 欧美三级午夜理伦三级| 美国一区二区三区在线播放| 国内自拍第二页| 成人动漫av在线| 日韩av片在线| 一区二区三区四区激情| 欧美一级片免费在线观看| 欧美三电影在线| 韩国av永久免费| 国产一区二区三区精品久久久 | 欧美视频一二区| 亚洲视频日韩精品| 国产原创视频在线观看| 992tv成人免费视频| 欧美xnxx| 成人一区二区在线| 视频一区中文| 高清无码视频直接看| 快she精品国产999| 亚洲精品无码久久久久久久| 99热这里都是精品| 手机看片国产日韩| 亚洲v中文字幕| 91高潮大合集爽到抽搐| 亚洲精品美女在线观看| 1stkiss在线漫画| 日本高清视频精品| www国产精品| 一本久久a久久精品vr综合| 一本色道久久综合一区 | 亚洲国产伊人| 鲁片一区二区三区| 韩国在线视频一区| 激情在线观看视频| 久久久久久综合| 国产一级在线免费观看| 欧美日韩亚洲综合一区二区三区| 人妻精品一区一区三区蜜桃91| 精品国产拍在线观看| 色香欲www7777综合网| 好吊色欧美一区二区三区| 综合激情婷婷| 五月激情五月婷婷| 日本一区免费视频| 日韩少妇裸体做爰视频| 欧美一区二区在线观看| 91社区在线观看播放| 欧美在线视频一二三| 2021年精品国产福利在线| 在线不卡视频一区二区| 奇米精品一区二区三区在线观看一| 亚洲一级av无码毛片精品| 亚洲精品国产成人久久av盗摄| 最近中文字幕免费观看| 亚洲欧美激情另类校园| 国产99在线| 国产精品久久亚洲7777| 综合久久婷婷| 污污视频网站在线| 国产精品久线在线观看| 国产91av在线播放| 亚洲人成在线观| 成人免费影院| 久热这里只精品99re8久| 亚洲欧洲日本mm| 超碰caoprom| 天天综合日日夜夜精品| 神马午夜一区二区| 97国产真实伦对白精彩视频8| 激情视频极品美女日韩| 久久99久久99精品| 北条麻妃一区二区三区| 国产大片中文字幕| 精品国产乱码久久久久久老虎| 欧美寡妇性猛交xxx免费| 国产成人精品自拍| 亚洲日本久久| 中文字幕狠狠干| 欧美最猛性xxxxx直播| 岛国大片在线观看| 国产精品免费久久久久影院| 青青草91久久久久久久久| 蜜桃免费在线视频| 国产精品不卡视频| av无码精品一区二区三区宅噜噜| 欧美成人中文字幕在线| eeuss鲁片一区二区三区| 男女超爽视频免费播放| 久久夜色精品国产噜噜av| 日韩欧美国产另类| 久久激情视频免费观看| www.成人网| 欧美a在线视频| 日本一区二区免费在线观看视频 | 亚洲一卡二卡三卡| 精品一二三四区| 免费网站看av| 亚洲国产成人精品一区二区 | 精品久久久久久中文字幕人妻最新| 欧美性猛交xxxx乱大交3| chinese偷拍一区二区三区| 国产91色在线免费| 五月婷婷六月综合| 亚洲欧美日韩色| 欧美午夜视频一区二区| 青青影院在线观看| 国产精品美女诱惑| 久热精品视频| 日本天堂中文字幕| 日韩精品中文字幕在线| 天天综合91| 国产一级爱c视频| 亚洲国产精华液网站w| 国产夫妻自拍av| 日本不卡免费高清视频| 51精产品一区一区三区| 在线精品一区二区三区| 在线成人小视频| 在线手机中文字幕| 一道本在线观看视频| 国产亚洲欧美日韩日本| 午夜精品久久久久久久91蜜桃| 一区二区成人在线| 狠狠人妻久久久久久综合蜜桃| 精品日韩中文字幕| 国产精品刘玥久久一区| 欧美视频1区|