初探mybatis

這里用mysql作為測(cè)試
需要的依賴包 mybatis-3.5.7.jar鼓蜒,mysql-connector-java-8.0.24.jar

使用xml配置

項(xiàng)目結(jié)構(gòu)


image.png

Teacher.java是簡(jiǎn)單的java bean
Main.java代碼如下

package com.ly1;

import com.ly1.entity.Teacher;
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 java.io.IOException;
import java.io.InputStream;

public class Main {
    public static void main(String[] args) throws IOException {
        /*final InputStream resourceAsStream =
                Main.class.getResourceAsStream("/mappings/mybatis-config.xml");
        Scanner scanner=new Scanner(resourceAsStream);
        while (scanner.hasNextLine()){
            System.out.println(scanner.nextLine());
        }*/
        String id="1";
        if(args.length==1){
            id=args[0] ;
        }
        String resource = "mappings/mybatis-config.xml";
        InputStream inputStream =  Resources.getResourceAsStream(
                resource
        );
        //或者下面形式也是可以的,注意地址
        /*resource = "/mappings/mybatis-config.xml";
        inputStream =  Main.class.getResourceAsStream(
                resource
        );*/
        SqlSessionFactory sqlSessionFactory
                = new SqlSessionFactoryBuilder().build(inputStream);
        //從factory中獲取sqlSession的實(shí)例
        try(SqlSession sqlSession=sqlSessionFactory.openSession()){
            long time1=System.currentTimeMillis();
            Teacher teacher= sqlSession.selectOne(
                    "org.mybatis1.example.TeacherMapper.selectTeacher",
                    id);
            long time2=System.currentTimeMillis();
            //這里可能是由于第一次連接數(shù)據(jù)庫(kù)需要耗費(fèi)一些時(shí)間
            System.out.println("第一次查詢使用了"+(time2-time1)+"毫秒");//700+
            time1=System.currentTimeMillis();
            Teacher teacher2= sqlSession.selectOne(
                    "org.mybatis1.example.TeacherMapper.selectTeacher",
                    3);
            time2=System.currentTimeMillis();
            System.out.println("第二次查詢使用了"+(time2-time1)+"毫秒");//1ms
            System.out.println(teacher2);
        }
    }
}

注意购裙,這里的org.mybatis1.example.TeacherMapper對(duì)應(yīng)的是mapper里面的namespace
TeacherMapper.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">
<!--這里namespace可以隨便寫(xiě)-->
<mapper namespace="org.mybatis1.example.TeacherMapper">
    <select id="selectTeacher" resultType="com.ly1.entity.Teacher">
        select * from teacher where id = #{id}
    </select>
</mapper>

mybatis-config.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.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/test"/>
                <property name="username" value="root"/>
                <property name="password" value="test.lwm"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <!--注意廓推,這里的地址要寫(xiě)resources下的絕對(duì)地址火窒,不能寫(xiě)相對(duì)地址-->
        <mapper resource="mappings\org\mybatis\example\TeacherMapper.xml" />
    </mappers>
</configuration>

稍微更改聊倔,使用Mapper注解進(jìn)行映射

在mybatis-config.xml中寫(xiě)上要掃描的包(mappers標(biāo)簽中)

<mappers>
        <!--注意,這里的地址要寫(xiě)resources下的絕對(duì)地址恋拷,不能寫(xiě)相對(duì)地址-->
        <mapper resource="mappings\org\mybatis\example\TeacherMapper.xml" />
        <!--注明要掃描的包-->
        <package name="com.ly1.mappers" />
    </mappers>

新增加的代碼


image.png

TeacherMapper.java

package com.ly1.mappers;
import com.ly1.entity.Teacher;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

@Mapper
public interface TeacherMapper {
    @Select("select * from teacher where id = #{id}")
    Teacher selectTeacher(@Param("id")String id);
}

使用Main.java文件中)

            //使用注解
            System.out.println("使用注解進(jìn)行查詢~");
            TeacherMapper teacherMapper=sqlSession.getMapper(TeacherMapper.class);
            final Teacher teacher2 = teacherMapper.selectTeacher("4");
            System.out.println(teacher2);
//替代了原先的使用語(yǔ)句,如下
/*Teacher teacher1= sqlSession.selectOne(
                    "org.mybatis1.example.TeacherMapper.selectTeacher",
                    3);*/
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末敢订,一起剝皮案震驚了整個(gè)濱河市王污,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌楚午,老刑警劉巖昭齐,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異矾柜,居然都是意外死亡阱驾,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)怪蔑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)里覆,“玉大人,你說(shuō)我怎么就攤上這事缆瓣⌒希” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵弓坞,是天一觀的道長(zhǎng)隧甚。 經(jīng)常有香客問(wèn)我,道長(zhǎng)昼丑,這世上最難降的妖魔是什么呻逆? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任夸赫,我火速辦了婚禮菩帝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘茬腿。我一直安慰自己呼奢,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布切平。 她就那樣靜靜地躺著握础,像睡著了一般。 火紅的嫁衣襯著肌膚如雪悴品。 梳的紋絲不亂的頭發(fā)上禀综,一...
    開(kāi)封第一講書(shū)人閱讀 49,792評(píng)論 1 290
  • 那天简烘,我揣著相機(jī)與錄音,去河邊找鬼定枷。 笑死孤澎,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的欠窒。 我是一名探鬼主播覆旭,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼岖妄!你這毒婦竟也來(lái)了型将?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤荐虐,失蹤者是張志新(化名)和其女友劉穎七兜,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體福扬,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡惊搏,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了忧换。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片恬惯。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖亚茬,靈堂內(nèi)的尸體忽然破棺而出酪耳,到底是詐尸還是另有隱情,我是刑警寧澤刹缝,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布碗暗,位于F島的核電站,受9級(jí)特大地震影響梢夯,放射性物質(zhì)發(fā)生泄漏言疗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一颂砸、第九天 我趴在偏房一處隱蔽的房頂上張望噪奄。 院中可真熱鬧,春花似錦人乓、人聲如沸勤篮。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)碰缔。三九已至,卻和暖如春戳护,著一層夾襖步出監(jiān)牢的瞬間金抡,已是汗流浹背瀑焦。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留梗肝,地道東北人蝠猬。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像统捶,于是被迫代替她去往敵國(guó)和親榆芦。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348

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