MyBatis--Mapper代理开发和MyBatisX插件使用

文章目录

    • 一、Mapper代理开发
    •     1、定义mapper接口
    •     2、设置mapper接口全限定名
    •     3、定义接口里面的方法
    •     4、修改sql映射文件为包扫描方式
    •     5、编码
    • 二、mybatisx插件的安装
    •     1、下载
    •     2、使用

一、Mapper代理开发

    1、定义mapper接口

定义与sql映射同名的mapper接口,将映射文件和mapper接口放在同一个包目录下。
1.配置sql映射文件
在resources下新建一个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="org.mybatis.example.BlogMapper">
  <select id="selectBlog" resultType="Blog">
    select * from Blog where id = #{id}
  </select>
</mapper>

修改id,类型,以及你的sql语句
MyBatis--Mapper代理开发和MyBatisX插件使用_第1张图片
2.定义mapper接口,这个接口方法名一定要和你的映射文件名对应,后续执行sql语句才能找到。
我这里mapper映射文件名称是UserMapper.xml,所以我需要定义一个叫UserMapper的接口。
MyBatis--Mapper代理开发和MyBatisX插件使用_第2张图片
3.将UserMapper借口和UserMapper.xml放置在同一个包目录下。
现在我的UserMapper借口在com.mybatis.mapper包下,而UserMapper.xml映射文件在resources包下。显然两个文件不在一个包目录下。
MyBatis--Mapper代理开发和MyBatisX插件使用_第3张图片
你可以把两个文件拖到一个包下,这是一种方法。只是这种方法复用性不好,对后期代码维护不友好。当然有其他办法,就是在resources目录下建一个和UserMapper相同目录的包,比如我这里就是com/mybatis/mapper,注意要用斜线,不能用点,但是建好包之后他会自动转化成为点,不用担心。然后把UserMapper.xml拖进去就行了。
在这里插入图片描述
那怎么证明他两在同一个包目录下呢?只需要编译后,在对应包目录下就可以看见两个在同一个目录下。
在这里插入图片描述
到现在定义mapper接口就成功了。

    2、设置mapper接口全限定名

这里mapper接口里面的全限定名就是前面定义的名称空间,也就是说一定需要和你sql映射文件中对应sql语句的namespace属性相同。
MyBatis--Mapper代理开发和MyBatisX插件使用_第4张图片

    3、定义接口里面的方法

接口里面定义的方法名要和sql映射文件的id属性相同,返回类型要和resultType类型相同。
MyBatis--Mapper代理开发和MyBatisX插件使用_第5张图片
MyBatis--Mapper代理开发和MyBatisX插件使用_第6张图片

    4、修改sql映射文件为包扫描方式

将mybatis-config.xml的sql映像修改为

	


    

    5、编码

步骤和MyBatis代码大致相同,只有第执行sql语句不同(MyBatis编码参考另一篇博客)
大致步骤如下:
1.创建一个对应的数据库的实体类,我数据库里面存放的是用户信息,所以我定义了一个User类。
2.将以下代码放在你的测试类或者自己定义的类里面
第一行主要用于获取驱动以及连接路径(我们在第二步配置核心文件里面已经配置了)
第二行就是把数据库的资源加载到一个字节输入流里面
第三行建立一个sqlSessionFactory对象,用于后面sql语句的执行

    String resource = "mybatis-config.xml";
    InputStream inputStream = Resources.getResourceAsStream(resource);
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

3.获取SqlSession对象,用来执行sql语句

	        SqlSession sqlSession = sqlSessionFactory.openSession();

4.执行sql

	//mapper代理就第三步和MyBatis不同
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    List users = mapper.selectAll();

5.释放资源

package com.mybatis.demo;


import com.mybatis.mapper.UserMapper;
import com.mybatis.pojo.User;
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.InputStream;
import java.util.List;

public class MyBatis002 {
    public static void main(String[] args) throws Exception {
//        1.加载核心配置文件,获取sqlSessionFactory对象
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//        2.获取SQLSession对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
//        3.执行sql
//        List user = sqlSession.selectList("mybatis.selectAll");
//        mapper代理就第三步和MyBatis不同
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        List<User> users = mapper.selectAll();

        System.out.println(users);

//        4.释放资源
        sqlSession.close();
    }
}

在这里插入图片描述

二、mybatisx插件的安装

    1、下载

MyBatis--Mapper代理开发和MyBatisX插件使用_第7张图片
MyBatis--Mapper代理开发和MyBatisX插件使用_第8张图片

然后点击apply,就可以了。如果点击后没有效果,就重新启动idea试一下。

    2、使用

如果出现蓝色或者红色小鸟,说明插件安装成功。
MyBatis--Mapper代理开发和MyBatisX插件使用_第9张图片
使用的时候主要有两个功能:
1.实现接口和sql映射文件的跳转。比如我需要找UserMapper的sql映射文件,只需要点一下红色小鸟就行了。如果需要找到映射文件对应的接口,只需要点一下蓝色小鸟。
MyBatis--Mapper代理开发和MyBatisX插件使用_第10张图片
MyBatis--Mapper代理开发和MyBatisX插件使用_第11张图片
2.定义接口时自动生成对应名称sql映射文件。
如我需要生成一个selectByuserName()方法,只需要点击Alt+enter,点击create statement。
插件可以自动给你生成sql映射文件框架,只需要你写里面的sql语句。
MyBatis--Mapper代理开发和MyBatisX插件使用_第12张图片
在这里插入图片描述
OK,mapper代理开发和mybatisx插件使用就介绍完了。

你可能感兴趣的:(mysql,java,开发语言,数据库,database,web)