本文主要是介绍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 mapperPUBLIC "-//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语句
2.定义mapper接口,这个接口方法名一定要和你的映射文件名对应,后续执行sql语句才能找到。
我这里mapper映射文件名称是UserMapper.xml,所以我需要定义一个叫UserMapper的接口。
3.将UserMapper借口和UserMapper.xml放置在同一个包目录下。
现在我的UserMapper借口在com.mybatis.mapper包下,而UserMapper.xml映射文件在resources包下。显然两个文件不在一个包目录下。
你可以把两个文件拖到一个包下,这是一种方法。只是这种方法复用性不好,对后期代码维护不友好。当然有其他办法,就是在resources目录下建一个和UserMapper相同目录的包,比如我这里就是com/mybatis/mapper,注意要用斜线,不能用点,但是建好包之后他会自动转化成为点,不用担心。然后把UserMapper.xml拖进去就行了。
那怎么证明他两在同一个包目录下呢?只需要编译后,在对应包目录下就可以看见两个在同一个目录下。
到现在定义mapper接口就成功了。
2、设置mapper接口全限定名
这里mapper接口里面的全限定名就是前面定义的名称空间,也就是说一定需要和你sql映射文件中对应sql语句的namespace属性相同。
3、定义接口里面的方法
接口里面定义的方法名要和sql映射文件的id属性相同,返回类型要和resultType类型相同。
4、修改sql映射文件为包扫描方式
将mybatis-config.xml的sql映像修改为
<!-- 加载sql映射文件-->
<mappers>
<!-- <mapper resource="com.mybatis.mapper.UserMapper.xml"/>--><package name="mapper接口的包名,例如我的是com.mybatis.mapper"/>
</mappers>
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<User> 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> 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、下载
然后点击apply,就可以了。如果点击后没有效果,就重新启动idea试一下。
2、使用
如果出现蓝色或者红色小鸟,说明插件安装成功。
使用的时候主要有两个功能:
1.实现接口和sql映射文件的跳转。比如我需要找UserMapper的sql映射文件,只需要点一下红色小鸟就行了。如果需要找到映射文件对应的接口,只需要点一下蓝色小鸟。
2.定义接口时自动生成对应名称sql映射文件。
如我需要生成一个selectByuserName()方法,只需要点击Alt+enter,点击create statement。
插件可以自动给你生成sql映射文件框架,只需要你写里面的sql语句。
OK,mapper代理开发和mybatisx插件使用就介绍完了。
这篇关于MyBatis--Mapper代理开发和MyBatisX插件使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!