mybatis01

1. 有了hibernate為什么要使用mybatis

Hibernate: 是一個(gè)標(biāo)準(zhǔn)的 ORM 框架(對(duì)象關(guān)系映射)。學(xué)習(xí)成本較高充石,不需要編寫sql語句颈畸,SQL語句自動(dòng)生成咐旧。對(duì)于sql語句的優(yōu)化蝶涩,修改比較困難理朋。
應(yīng)用場(chǎng)景:
適合用于sql語句簡(jiǎn)單的絮识,效率要求不是特別高的項(xiàng)目。

Mybatis: 專注于sql語句嗽上,對(duì)象映射和輸入輸出次舌,都由框架幫你完成,所以屬于半 ORM系統(tǒng)兽愤,
適用場(chǎng)景:
sql語句邏輯復(fù)雜彼念,效率要求特別高的應(yīng)用。

2. mybatis結(jié)構(gòu)圖

Snip20180910_14.png

3. helloMybatis

3.1下載mybatis包

https://github.com/mybatis/mybatis-3/releases

然后導(dǎo)包

3.2書寫pojo的User

User

 /**
     *
     */
    private static final long serialVersionUID = 1L;
    private Integer id;
    private String username;// 用戶姓名
    private String sex;// 性別
    private String address;// 地址

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", sex='" + sex + '\'' +
                ", address='" + address + '\'' +
                '}';
    }

    public static long getSerialVersionUID() {
        return serialVersionUID;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }


    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }
}

3.3 書寫mapper接口烹看,接口方法需要遵循四個(gè)原則

public interface UserMapper {

    //遵循四個(gè)原則
    //1.接口 方法名  == User.xml 中 id 名
    //2.返回值類型  與  Mapper.xml文件中返回值類型要一致
    //3.方法的入?yún)㈩愋?與Mapper.xml中入?yún)⒌念愋鸵恢?    //4.命名空間 綁定此接口
    public User findUserById(Integer id);


    public User findUserByUsername(String username);


    public Integer insertUser(User user);


    public void updateUser(User user);


    public void deleteUserById(int i);

}

3.4 書寫UserMapper.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="mapper.UserMapper">

    <!-- 通過ID查詢一個(gè)用戶 -->
    <select id="findUserById" parameterType="Integer" resultType="pojo.User">
        select * from user where id = #{v};
    </select>


    <!-- //根據(jù)用戶名稱模糊查詢用戶列表
    #{}    select * from user where id = 国拇?    占位符  ? ==  '五'
    ${}    select * from user where username like '%五%'  字符串拼接
     -->
    <select id="findUserByUsername" parameterType="String" resultType="pojo.User">
        select * from user WHERE username LIKE "%"#{v}"%";
    </select>

    <insert id="insertUser" parameterType="pojo.User">
        // 返回插入數(shù)據(jù)的id
        <selectKey keyProperty="id" resultType="Integer" order="AFTER">
          SELECT LAST_INSERT_ID();
        </selectKey>

        INSERT INTO user (username, address, sex) VALUES (#{username}, #{address}, #{sex});

     </insert>

    <update id="updateUser" parameterType="pojo.User">
        UPDATE user
        SET username = #{username}, address = #{address}, sex = #{sex} WHERE id = #{id};
    </update>

    <delete id="deleteUserById" parameterType="Integer">
        DELETE FROM user WHERE id = #{id}
    </delete>

</mapper>


3.5 測(cè)試UserMapperTest

public class UserMapperTest {

    @Test
    public void findUserById() throws IOException {
        //加載核心配置文件
        String resource = "sqlMapConfig.xml";

        InputStream in = Resources.getResourceAsStream(resource);
        //創(chuàng)建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
        //創(chuàng)建SqlSession
        SqlSession sqlSession = sqlSessionFactory.openSession();

        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

        User user = userMapper.findUserById(1);

        System.out.println(user);
    }

    @Test
    public void testFindUserByUsername() throws IOException {

        //加載核心配置文件
        String resource = "sqlMapConfig.xml";

        InputStream in = Resources.getResourceAsStream(resource);
        //創(chuàng)建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
        //創(chuàng)建SqlSession
        SqlSession sqlSession = sqlSessionFactory.openSession();

        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

        System.out.println(userMapper.findUserByUsername("張污"));

    }

    @Test
    public void insertUser() throws IOException {

        //加載核心配置文件
        String resource = "sqlMapConfig.xml";

        InputStream in = Resources.getResourceAsStream(resource);
        //創(chuàng)建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
        //創(chuàng)建SqlSession
        SqlSession sqlSession = sqlSessionFactory.openSession();


        User user = new User();
        user.setUsername("阿珍");
        user.setAddress("北京");
        user.setSex("男");

        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        userMapper.insertUser(user);

        sqlSession.commit();

        // 用戶保存好之后洛史,獲取到用戶的id進(jìn)行其他的后續(xù)操作
        System.out.println(user.getId());
    }


    @Test
    public void updateUserById() throws IOException {

        //加載核心配置文件
        String resource = "sqlMapConfig.xml";

        InputStream in = Resources.getResourceAsStream(resource);
        //創(chuàng)建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
        //創(chuàng)建SqlSession
        SqlSession sqlSession = sqlSessionFactory.openSession();


        User user = new User();
        user.setId(1);
        user.setUsername("張三");
        user.setAddress("北京33");
        user.setSex("男33");

        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        userMapper.updateUser(user);

        sqlSession.commit();
    }


    @Test
    public void deleteUserById() throws IOException {

        //加載核心配置文件
        String resource = "sqlMapConfig.xml";

        InputStream in = Resources.getResourceAsStream(resource);
        //創(chuàng)建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
        //創(chuàng)建SqlSession
        SqlSession sqlSession = sqlSessionFactory.openSession();


        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

        userMapper.deleteUserById(3);

        sqlSession.commit();
    }


}

4.問題

4.1 關(guān)于模糊查詢時(shí)惯殊,中文查不到結(jié)果的問題

要將數(shù)據(jù)庫設(shè)置成UTF-8的編碼

<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://123.206.7.239/xiaobang?characterEncoding=UTF-8" />
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市也殖,隨后出現(xiàn)的幾起案子土思,更是在濱河造成了極大的恐慌,老刑警劉巖忆嗜,帶你破解...
    沈念sama閱讀 219,110評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件己儒,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡捆毫,警方通過查閱死者的電腦和手機(jī)闪湾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绩卤,“玉大人途样,你說我怎么就攤上這事”舯铮” “怎么了何暇?”我有些...
    開封第一講書人閱讀 165,474評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)凛驮。 經(jīng)常有香客問我裆站,道長(zhǎng),這世上最難降的妖魔是什么黔夭? 我笑而不...
    開封第一講書人閱讀 58,881評(píng)論 1 295
  • 正文 為了忘掉前任宏胯,我火速辦了婚禮,結(jié)果婚禮上本姥,老公的妹妹穿的比我還像新娘肩袍。我一直安慰自己,他們只是感情好扣草,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評(píng)論 6 392
  • 文/花漫 我一把揭開白布了牛。 她就那樣靜靜地躺著颜屠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鹰祸。 梳的紋絲不亂的頭發(fā)上甫窟,一...
    開封第一講書人閱讀 51,698評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音蛙婴,去河邊找鬼粗井。 笑死,一個(gè)胖子當(dāng)著我的面吹牛街图,可吹牛的內(nèi)容都是我干的浇衬。 我是一名探鬼主播,決...
    沈念sama閱讀 40,418評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼餐济,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼耘擂!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起絮姆,我...
    開封第一講書人閱讀 39,332評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤醉冤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后篙悯,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蚁阳,經(jīng)...
    沈念sama閱讀 45,796評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評(píng)論 3 337
  • 正文 我和宋清朗相戀三年鸽照,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了螺捐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,110評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡矮燎,死狀恐怖定血,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情漏峰,我是刑警寧澤糠悼,帶...
    沈念sama閱讀 35,792評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站浅乔,受9級(jí)特大地震影響倔喂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜靖苇,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評(píng)論 3 331
  • 文/蒙蒙 一席噩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧贤壁,春花似錦悼枢、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽莹妒。三九已至,卻和暖如春绰上,著一層夾襖步出監(jiān)牢的瞬間旨怠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評(píng)論 1 272
  • 我被黑心中介騙來泰國打工蜈块, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鉴腻,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,348評(píng)論 3 373
  • 正文 我出身青樓百揭,卻偏偏與公主長(zhǎng)得像爽哎,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子器一,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評(píng)論 2 355

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

  • 1 Mybatis入門 1.1 單獨(dú)使用jdbc編程問題總結(jié) 1.1.1 jdbc程序 上邊使...
    哇哈哈E閱讀 3,307評(píng)論 0 38
  • 我的童年像一個(gè)童話故事课锌,我之所以會(huì)這么相信,當(dāng)然是因?yàn)槲矣幸粋€(gè)童話故事般的父親盹舞。父親是位老師产镐,是那...
    子姝云閱讀 893評(píng)論 1 0
  • 1. github 地址 hsweb-framework 2. 應(yīng)用場(chǎng)景 后臺(tái)管理系統(tǒng). 完全開源的后臺(tái)管理系統(tǒng)....
    小皮球_1927閱讀 5,338評(píng)論 1 1
  • 沒有突然的成功阔加,也不會(huì)有突然的失敗残吩。 沒有突然的開始冬阳,也不會(huì)有突然的結(jié)束。 每個(gè)突然之前都有長(zhǎng)長(zhǎng)的軌跡获印, 只因成敗...
    無間行者lee閱讀 338評(píng)論 0 0