3-Mybatis高級(jí)

1.Mybatis 注解開發(fā)

2.Mybatis 注解實(shí)現(xiàn)多表操作

3.Mybatis 構(gòu)建SQL語(yǔ)句

4.Mybatis 案例實(shí)現(xiàn)

1.Mybatis 注解開發(fā)

  • 常用注解
    @Select("查詢的SQL語(yǔ)句"): 執(zhí)行查詢操作注解
    @Insert("新增的SQL語(yǔ)句"): 執(zhí)行新增操作注解
    @Update("修改的SQL語(yǔ)句"): 執(zhí)行修改操作注解
    @Delete("刪除的SQL語(yǔ)句"): 執(zhí)行刪除操作注解
  • 配置映射關(guān)系
    <!--配置映射關(guān)系-->
    <mappers>
        <package name="接口所在包"/>
    </mappers>

注解實(shí)現(xiàn)查詢操作
1.創(chuàng)建接口和查詢方法
2.在核心配置文件中配置映射關(guān)系
3.編寫測(cè)試類

  • 封裝類
public class Student {
   private Integer id;
   private String name;
   private Integer age;
  • 接口類-注解方法編寫sql語(yǔ)句
public interface StudentMapper {
    //查詢?nèi)康牟僮?    @Select("SELECT * FROM student")
    public abstract List<Student> selectAll();
}
  • 核心配置文件,只需添加配置文件,不需要加載映射配置文件標(biāo)簽
    <!--配置映射關(guān)系-->
    <mappers>
        <package name="com.itheima.mapper"/>
    </mappers>
  • 測(cè)試單元
public class Test01 {
    @Test
    public void selectAll() throws IOException {
        //1.加載核心配置文件
        InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
        //2.獲取SqlSession工廠類對(duì)象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        //3.通過工廠類對(duì)象獲取SqlSession對(duì)象
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        //4.獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
        StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
        //調(diào)用實(shí)現(xiàn)類中的方法,接收結(jié)果
        List<Student> list = mapper.selectAll();
        //處理結(jié)果
        for (Student student : list) {
            System.out.println(student);
        }
        sqlSession.close();
        is.close();
    }
}
  • 測(cè)試結(jié)果
    測(cè)試結(jié)果

注解實(shí)現(xiàn)新增操作
1.創(chuàng)建接口和新增方法
2.在核心配置文件中配置映射關(guān)系
3.編寫測(cè)試類

  • 封裝類不變
  • 接口類- 新增注解方法編寫SQL語(yǔ)句
    //新增操作
    @Insert("insert into student values(#{id},#{name},#{age})")
    public abstract Integer insert(Student stu);
  • 核心配置文件不變
  • 測(cè)試單元
    @Test
    public void insert() throws IOException {
        //注意: 這里前面四個(gè)步驟和查詢的測(cè)試單元一樣,我這里省略了..........
        //調(diào)用實(shí)現(xiàn)類中的方法,接收結(jié)果
        Student stu1 = new Student(12, "金吒", 555);
        Integer insert = mapper.insert(stu1);
        //處理結(jié)果
        System.out.println(insert);
        sqlSession.close();
        is.close();
    }
  • 測(cè)試結(jié)果
    測(cè)試結(jié)果

注解實(shí)現(xiàn)修改操作

  • 封裝類不變
  • 接口類- 修改注解方法編寫SQL語(yǔ)句
    //修改操作
    @Update("update student set name=#{name},age=#{age} where id=#{id}")
    public abstract Integer update(Student stu);
  • 核心配置文件不變
  • 測(cè)試單元
 @Test
    public void upadte() throws IOException {
        //注意: 這里前面四個(gè)步驟和查詢的測(cè)試單元一樣,我這里省略了..........
        //調(diào)用實(shí)現(xiàn)類中的方法,接收結(jié)果
        Student stu1 = new Student(12, "哪吒", 18);
        Integer result= mapper.update(stu1);
        //處理結(jié)果
        System.out.println(result);
        sqlSession.close();
        is.close();
    }
  • 測(cè)試結(jié)果
    測(cè)試結(jié)果

注解實(shí)現(xiàn)刪除操作

  • 封裝類不變
  • 接口類- 刪除注解方法編寫SQL語(yǔ)句
    //刪除操作
    @Delete("delete from student where id=#{id}")
    public abstract Integer delete(Integer id);
  • 核心配置文件不變
  • 測(cè)試單元
    @Test
    public void delete() throws IOException {
        //注意: 這里前面四個(gè)步驟和查詢的測(cè)試單元一樣,我這里省略了..........
        //調(diào)用實(shí)現(xiàn)類中的方法,接收結(jié)果
        Integer result = mapper.delete(12);
        //處理結(jié)果
        System.out.println(result);
        sqlSession.close();
        is.close();
    }
  • 測(cè)試結(jié)果
    測(cè)試結(jié)果

2.Mybatis 注解實(shí)現(xiàn)多表操作

一對(duì)一

  • @Results: 封裝映射關(guān)系的父注解
    Result[] value(): 定義了Result數(shù)組
  • @Restult: 封裝映射關(guān)系的子注解
    column屬性: 查詢出的表中字段名稱
    property屬性: 實(shí)體對(duì)象中的屬性名稱
    javaType屬性: 被包含對(duì)象的數(shù)據(jù)類型
    one屬性: 一對(duì)一查詢固定屬性
  • @One: 一對(duì)一查詢的注解
    select屬性: 指定調(diào)用某個(gè)接口中的方法
  • 封裝對(duì)象
//get,set,toString等方法省略
public class Card {
    private Integer id;
    private String number;
    private  Person P;
}
//get,set,toString等方法省略
public class Person {
    private Integer id;
    private String name;
    private Integer age;
}
  • 核心配置文件
    <!--配置映射關(guān)系-->
    <mappers>
        <package name="com.itheima.one_to_one"/>
    </mappers>
  • 查詢?nèi)拷涌?/li>
//一對(duì)一注解開發(fā)方式
public interface CardMapper {
    //查詢?nèi)?    @Select("select * from card")
    @Results({
     @Result(column = "id",property = "id"),
     @Result(column = "number",property = "number"),
     @Result(
             property = "P",            //被包含對(duì)象的變量名
             javaType = Person.class,   //被包含對(duì)象的實(shí)際數(shù)據(jù)類型
             column = "pid",            //根據(jù)查詢處的card表中的pid字段,來查詢person表
             /*
             one,@One: 一對(duì)一查詢的固定寫法
             select屬性: 指定調(diào)用哪個(gè)接口中的哪個(gè)方法
              */
             one=@One(select ="com.itheima.one_to_one.PersonMapper.selectById" )
        )
    })
    public abstract List<Card> selectAll();

}
  • 根據(jù)id查詢接口
public interface PersonMapper {
    //根據(jù)id查詢
    @Select("select * from person where id=#{id}")
    public abstract Person selectById(Integer id);

}
  • 測(cè)試單元
public class Test01 {
    @Test
    public void selectAll() throws IOException {
        //加載核心配置文件
        InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
        //獲取SqlSession工廠類對(duì)象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        //通過工廠類對(duì)象獲取SqlSession對(duì)象
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        //獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
        CardMapper mapper = sqlSession.getMapper(CardMapper.class);
        //調(diào)用實(shí)現(xiàn)類中的方法,接收結(jié)果
        List<Card> list = mapper.selectAll();
        //處理結(jié)果
        for (Card card : list) {
            System.out.println(card);
        }
        sqlSession.close();
        is.close();
    }
}
  • 測(cè)試結(jié)果
    測(cè)試結(jié)果

一對(duì)多

  • many屬性: 一對(duì)多查詢固定屬性
  • @Many: 一對(duì)多查詢的注解
    select屬性: 指定調(diào)用某個(gè)接口中的方法
  • 封裝類
//get,set,等方法省略
public class Person {
    private Integer id;
    private String name;
    private Integer age;
}
//get,set,等方法省略
public class Classes {
    private Integer id; //主鍵id
    private  String name;   //班級(jí)名稱
    private List<Student> students; //班級(jí)中所有學(xué)生對(duì)象
  • 一對(duì)多的注解開發(fā)的接口
public interface ClassesMapper {
    //查詢?nèi)?    @Select("Select * from classes")
    @Results({
            @Result(column = "id",property = "id"),
            @Result(column = "name",property = "name"),
            @Result(
                    property = "students",  //被包含對(duì)象的變量名
                    javaType = List.class,  //被包含對(duì)象的數(shù)據(jù)類型
                    column = "id",   //根據(jù)查詢處的classes表的id字段來查詢student表
                    /*
                    一對(duì)多固定的寫法
                     */
                    many=@Many(select = "com.itheima.one_to_many.StudentMapper.selectById")
            )
    })
    public abstract List<Classes> selectAll();
}
  • 以ClassMapper接口的查詢結(jié)果的id,作為StudentMapper接口中查詢方法的參數(shù)
public interface StudentMapper {
    //根據(jù)id查詢
    @Select("Select * from student where cid=#{id}")
    public abstract List<Student> selectById(Integer id);
}
  • 測(cè)試單元
public class Test1 {
    @Test
    public void selectAll() throws IOException {
        //加載核心配置文件
        InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
        //獲取SqlSession工廠類對(duì)象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        //通過工廠類對(duì)象獲取SqlSession對(duì)象
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        //獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
        ClassesMapper mapper = sqlSession.getMapper(ClassesMapper.class);
        //調(diào)用實(shí)現(xiàn)類中的方法,接收結(jié)果
        List<Classes> list = mapper.selectAll();
        //處理結(jié)果
        for (Classes cls : list) {
            System.out.println(cls.getId()+","+cls.getName());
            List<Student> stu = cls.getStudents();
            for (Student student : stu) {
                System.out.println(student);
            }
        }
        sqlSession.close();
        is.close();
    }
}
  • 測(cè)試結(jié)果
    測(cè)試結(jié)果

多對(duì)多查詢

  • 封裝類
public class Course {
    private Integer id; //主鍵id
    private String name;   //課程名稱
}
public class StudentAddCource {
    private Integer id; //主鍵id
    private String name;    //學(xué)生新明
    private Integer age;    //學(xué)生年齡
    private List<Course> courses;   //指當(dāng)前學(xué)生所選擇的課程集合
}
  • 接口
public interface CourseMapper {
    //根據(jù)id查詢
    @Select("select c.id,c.name from stu_cr sc,course c where sc.cid=c.id and sc.sid=#{id}")
    public  abstract List<Course> selectById();
}
  • 查詢所有學(xué)生接口,通過結(jié)果的id,調(diào)用CourseMapper中的根據(jù)id查詢的方法
public interface StudentMapper {
    //查詢?nèi)?    @Select("SELECT DISTINCT s.id,s.name,s.age FROM student s, stu_cr sc WHERE sc.sid=s.id")
  //這條語(yǔ)句主要是篩選掉沒有選課的學(xué)生
    @Results({
            @Result(column = "id",property = "id"),
            @Result(column = "name",property = "name"),
            @Result(column = "age",property = "age"),
            @Result(
                    property = "courses",
                    javaType = List.class,
                    column = "id",
                    many =@Many(select = "com.itheima.many_to_many.CourseMapper.selectById")
            )
    })
    public  abstract List<StudentAddCource> selectAll();
}
  • 測(cè)試單元
 @org.junit.Test
    public void selectAll() throws IOException {
        //加載核心配置文件
        InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
        //獲取SqlSession工廠類對(duì)象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        //通過工廠類對(duì)象獲取SqlSession對(duì)象
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        //獲取StudentMapper接口的實(shí)現(xiàn)類對(duì)象
        StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
        //調(diào)用實(shí)現(xiàn)類中的方法,接收結(jié)果
        List<StudentAddCource> studentAddCources = mapper.selectAll();
        //處理結(jié)果
        for (StudentAddCource cls : studentAddCources) {
            System.out.println(cls.getId()+","+cls.getName()+","+cls.getAge());
            List<Course> courses = cls.getCourses();
            for (Course cours : courses) {
                System.out.println("\t"+cours);
            }
        }
        sqlSession.close();
        is.close();
    }
  • 測(cè)試結(jié)果
    測(cè)試結(jié)果

3.Mybatis 構(gòu)建SQL語(yǔ)句

  • org.apache.ibatis.jdbc.SQL功能類,專門用于構(gòu)建SQL語(yǔ)句


    常用方法
  • 定義功能類并提供獲取查詢的SQL語(yǔ)句的方法
  • @SelectProvider: 生成查詢用的SQL語(yǔ)句注解
    type屬性: 生成SQL語(yǔ)句功能類對(duì)象
    method屬性: 指定調(diào)用方法
//定義方法,返回查詢的SQL語(yǔ)句
    public String getSelectAll(){
        String sql = new SQL() {
            {
                SELECT("*");
                FROM("student");
            }
        }.toString();
        return sql;
    }
  • 定義功能類并提供獲取新增的SQL語(yǔ)句的方法
  • @InsertProvider: 生成新增用的SQL語(yǔ)句注解
    type屬性: 生成SQL語(yǔ)句功能類對(duì)象
    method屬性: 指定調(diào)用方法
//定義方法,返回添加的SQL語(yǔ)句
    public String getInsert(Student stu){
        return new SQL() {
            {
                INSERT_INTO("student");
                INTO_VALUES("#{id},#{name},#{age}");
            }
        }.toString();
    }
  • 定義功能類并提供獲取修改的SQL語(yǔ)句的方法
  • @UpdateProvider: 生成修改用的SQL語(yǔ)句注釋
    type屬性: 生成SQL語(yǔ)句功能類對(duì)象
    method屬性: 指定調(diào)用方法
//定義方法,返回修改的SQL語(yǔ)句
    public String getUpdate(Student stu){
        return new SQL() {
            {
                UPDATE("student");
                SET("name=#{name},age=#{age}");
                WHERE("id=#{id}");
            }
        }.toString();
    }
  • 定義功能類并提供獲取刪除的SQL語(yǔ)句的方法
  • DeleteProvider: 生成刪除用的SQL語(yǔ)句注解
    type屬性: 生成SQL語(yǔ)句功能類對(duì)象
    method屬性: 指定調(diào)用方法
//定義方法,返回修改的SQL語(yǔ)句
    public String getDelete(Integer id){
        return new SQL() {
            {
                DELETE_FROM("student");
                WHERE("id=#{id}");
            }
        }.toString();
    }

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市啰劲,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌戒财,老刑警劉巖怪瓶,帶你破解...
    沈念sama閱讀 212,029評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡怎虫,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門困介,熙熙樓的掌柜王于貴愁眉苦臉地迎上來大审,“玉大人,你說我怎么就攤上這事逻翁〖⑴” “怎么了?”我有些...
    開封第一講書人閱讀 157,570評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵八回,是天一觀的道長(zhǎng)酷愧。 經(jīng)常有香客問我驾诈,道長(zhǎng),這世上最難降的妖魔是什么溶浴? 我笑而不...
    開封第一講書人閱讀 56,535評(píng)論 1 284
  • 正文 為了忘掉前任乍迄,我火速辦了婚禮,結(jié)果婚禮上士败,老公的妹妹穿的比我還像新娘闯两。我一直安慰自己,他們只是感情好谅将,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,650評(píng)論 6 386
  • 文/花漫 我一把揭開白布漾狼。 她就那樣靜靜地躺著,像睡著了一般饥臂。 火紅的嫁衣襯著肌膚如雪逊躁。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,850評(píng)論 1 290
  • 那天隅熙,我揣著相機(jī)與錄音稽煤,去河邊找鬼。 笑死囚戚,一個(gè)胖子當(dāng)著我的面吹牛酵熙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播驰坊,決...
    沈念sama閱讀 39,006評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼匾二,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了庐橙?” 一聲冷哼從身側(cè)響起假勿,我...
    開封第一講書人閱讀 37,747評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎态鳖,沒想到半個(gè)月后转培,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,207評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡浆竭,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,536評(píng)論 2 327
  • 正文 我和宋清朗相戀三年浸须,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邦泄。...
    茶點(diǎn)故事閱讀 38,683評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡删窒,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出顺囊,到底是詐尸還是另有隱情肌索,我是刑警寧澤,帶...
    沈念sama閱讀 34,342評(píng)論 4 330
  • 正文 年R本政府宣布特碳,位于F島的核電站诚亚,受9級(jí)特大地震影響晕换,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜站宗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,964評(píng)論 3 315
  • 文/蒙蒙 一闸准、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧梢灭,春花似錦夷家、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至颂暇,卻和暖如春缺谴,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背耳鸯。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膀曾,地道東北人县爬。 一個(gè)月前我還...
    沈念sama閱讀 46,401評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像添谊,于是被迫代替她去往敵國(guó)和親财喳。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,566評(píng)論 2 349

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