MyBatis02

學(xué)習(xí)了3種使用方式

案例鏈接(包含jar包): https://pan.baidu.com/s/1hykf9d2IEFoEPl8XlMWaqQ 提取碼: m342

方式二:

通過dao層去調(diào)用xml中的方法,跟方式一類似

步驟1:配置SqlMapConfig.xml和Car.xml文件身冬,和方式一完全一樣狸页,還有在com.hello.pojo下新建Car類

步驟2:新建com.hello.dao包并在里面新建一個(gè)CarDao接口和實(shí)現(xiàn)類CarDaoImpl

CarDao接口中有一些需要用到的增刪改查的未實(shí)現(xiàn)方法眷茁,比如

package com.hello.dao;

import java.util.List;

import com.hello.pojo.Car;

public interface CarDao {

// 根據(jù) id 查車

public Car findCarById(Integer id);

// 根據(jù) name 模糊查詢

public List<Car> findCarByName(String name);

}

實(shí)現(xiàn)類CarDaoImpl中上面那些方法的實(shí)現(xiàn)悦即,說是實(shí)現(xiàn)其實(shí)并不需要我們?nèi)プ鲈鰟h改查的操作斤斧,因?yàn)槲覀円呀?jīng)在Car.xml里面做好了這些操作厚宰,所以在CarDaoImpl中我們只需要調(diào)用Car.xml中的方法即可到踏。

package com.hello.dao;

import java.util.List;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import com.hello.dao.CarDao;

import com.hello.pojo.Car;

public class CarDaoImpl implements CarDao {

private SqlSessionFactory factory;

public CarDaoImpl() {

super();

}

public CarDaoImpl(SqlSessionFactory factory) {

super();

this.factory = factory;

}

@Override

public Car findCarById(Integer id) {

// 獲取 SqlSession

SqlSession session = factory.openSession();

return session.selectOne("aa.findCarById", id);

}

@Override

public List<Car> findCarByName(String name) {

// 獲取 SqlSession

SqlSession session = factory.openSession();

return session.selectList("aa.findCarByName", name);

}

}

其中,里面的factory對(duì)象需要我們?cè)跍y(cè)試類那邊調(diào)用構(gòu)造方法傳過來昵济,具體測(cè)試類怎么實(shí)現(xiàn)智绸,看下面

步驟3:創(chuàng)建測(cè)試類CarTest

package com.hello.test;

import java.io.IOException;

import java.io.InputStream;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import org.junit.Before;

import org.junit.Test;

import com.hello.dao.CarDaoImpl;

import com.hello.pojo.Car;

public class CarTest {

private SqlSessionFactory factory;

// @Before 注解野揪,會(huì)在 @Test 注解之前執(zhí)行

@Before

public void getFactory() throws IOException {

// 1. 加載核心配置文件

InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");

// 2. 獲取 SqlSessionFactory

SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();

factory = builder.build(is);

}

@Test

public void findCarById() throws Exception {

CarDaoImpl cdao = new CarDaoImpl(factory);

Car car = cdao.findCarById(1);

System.out.println("我找到的車:" + car);

}

}

執(zhí)行測(cè)試方法findCarById(),因?yàn)?getFactory() 前加了注解@Before瞧栗,所以會(huì)在執(zhí)行findCarById()方法之前執(zhí)行斯稳,也就得到了factory對(duì)象,通過new CarDaoImpl(factory)把factory對(duì)象傳過去沼溜,CarDaoImpl類中也就得到了factory對(duì)象平挑。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市系草,隨后出現(xiàn)的幾起案子通熄,更是在濱河造成了極大的恐慌,老刑警劉巖找都,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件唇辨,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡能耻,警方通過查閱死者的電腦和手機(jī)赏枚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來晓猛,“玉大人饿幅,你說我怎么就攤上這事〗渲埃” “怎么了栗恩?”我有些...
    開封第一講書人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長洪燥。 經(jīng)常有香客問我磕秤,道長,這世上最難降的妖魔是什么捧韵? 我笑而不...
    開封第一講書人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任市咆,我火速辦了婚禮,結(jié)果婚禮上再来,老公的妹妹穿的比我還像新娘蒙兰。我一直安慰自己,他們只是感情好芒篷,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開白布搜变。 她就那樣靜靜地躺著,像睡著了一般梭伐。 火紅的嫁衣襯著肌膚如雪痹雅。 梳的紋絲不亂的頭發(fā)上仰担,一...
    開封第一講書人閱讀 51,258評(píng)論 1 300
  • 那天糊识,我揣著相機(jī)與錄音绩社,去河邊找鬼。 笑死赂苗,一個(gè)胖子當(dāng)著我的面吹牛愉耙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播拌滋,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼朴沿,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了败砂?” 一聲冷哼從身側(cè)響起赌渣,我...
    開封第一講書人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎昌犹,沒想到半個(gè)月后坚芜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡斜姥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年鸿竖,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片铸敏。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡缚忧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出杈笔,到底是詐尸還是另有隱情闪水,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布桩撮,位于F島的核電站敦第,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏店量。R本人自食惡果不足惜芜果,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望融师。 院中可真熱鬧右钾,春花似錦、人聲如沸旱爆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽怀伦。三九已至脆烟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間房待,已是汗流浹背邢羔。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來泰國打工驼抹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人拜鹤。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓框冀,卻偏偏與公主長得像,于是被迫代替她去往敵國和親敏簿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子明也,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1 Mybatis入門 1.1 單獨(dú)使用jdbc編程問題總結(jié) 1.1.1 jdbc程序 上邊使...
    哇哈哈E閱讀 3,306評(píng)論 0 38
  • Spring 技術(shù)筆記Day 1 預(yù)熱知識(shí)一、 基本術(shù)語Blob類型惯裕,二進(jìn)制對(duì)象Object Graph:對(duì)象圖...
    OchardBird閱讀 973評(píng)論 0 2
  • 1 版本說明 springboot:2.0 jdk:1.8 2 創(chuàng)建springBoot項(xiàng)目 創(chuàng)建項(xiàng)目時(shí)勾選必要w...
    Java小鋪閱讀 786評(píng)論 2 5
  • 學(xué)習(xí)了3種使用方式 案例鏈接(包含jar包): https://pan.baidu.com/s/1hykf9d2I...
    BALE_11閱讀 495評(píng)論 0 1
  • 這兩天被這部影片刷屏了温数,所以昨天下午翹了班,拉著老公蜻势,犧牲了午休時(shí)間在電影院看了一遍帆吻。真的好看!從中我看到...
    菲姨所思閱讀 280評(píng)論 3 1