-
mybatis 是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力
去处理加载驱动、创建连接、创建statement等繁杂的过程。
-
mybatis通过xml或注解的方式将要执行的各种 statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。
-
最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc 进行了封装,屏蔽了jdbc api 底层访问细节,使我们不用与jdbc api打交道,就可以完成对数据库的持久化操作
MyBatis开发步骤: ① 添加MyBatis的坐标 ② 创建user数据表 ③ 编写User实体类 ④ 编写映射文件UserMapper.xml ⑤ 编写核心文件SqlMapConfig.xml ⑥ 编写测试类
项目结构图
3、配置环境 3、1依赖坐标3、2创建数据库 3、3编写实体类org.mybatis mybatis 3.4.5 mysql mysql-connector-java 5.1.6 runtime junit junit 4.12 test log4j log4j 1.2.12
public class User {
private int id;
private String username;
private String password;
//省略get个set方法
}
3、4. 编写UserMapper映射文件
3、5编写MyBatis核心文件select * from User
3、6 编写测试代码//映射路径
package com.geo.MyBatis.Test;
import com.geo.MyBatis.domain.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 Test {
public static void main(String[] args) throws Exception{
//加载核心配置文件
InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml");
//获得sqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//获得sqlSession对象
SqlSession sqlSession = sqlSessionFactory.openSession();
//执行sql语句
List userList = sqlSession.selectList("userMapper.findAll");
//打印结果
System.out.println(userList);
//释放资源
sqlSession.close();
}
}
输出结果
4、MyBatis的核心配置文件概述通过上面的一个例子我们对mybatis有了一个简单的了解,接下来我们对它的配置文件进行简单的分析
4、1. environments标签数据库环境的配置,支持多环境配置
其中,事务管理器(transactionManager)类型有两种: • JDBC:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。 • MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置 为 false 来阻止它默认的关闭行为。 其中,数据源(dataSource)类型有三种: • UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。 • POOLED:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。 • JNDI:这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置 一个 JNDI 上下文的引用。4、2 mapper标签
该标签的作用是加载映射的,加载方式有如下几种: • 使用相对于类路径的资源引用,例如:4、3. Properties标签 4、4 typeAliases标签• 使用完全限定资源定位符(URL),例如: • 使用映射器接口实现类的完全限定类名,例如: • 将包内的映射器接口实现全部注册为映射器,例如:
上面我们是自定义的别名,mybatis框架已经为我们设置好的一些常用的类型的别名5、MyBatis的简单增删改查 5、1 UserMapper映射文件
5、2 Mybatis测试
package com.geo.MyBatis.Test;
import com.geo.MyBatis.domain.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 org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
public class MybatisTest {
@Test
//删除操作
public void delete() throws IOException {
//获得核心配置文件
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得session工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//获得session回话对象
SqlSession sqlSession = sqlSessionFactory.openSession();
//执行操作 参数:namespace+id
int res = sqlSession.delete("userMapper.delete",1);
if(res > 0){
System.out.println("执行成功!影响行数:"+res);
}
//mybatis执行更新操作 提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
@Test
//查询操作
public void findAll() throws IOException {
//获得核心配置文件
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得session工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//获得session回话对象
SqlSession sqlSession = sqlSessionFactory.openSession();
//执行sql语句
List userList = sqlSession.selectList("userMapper.findAll");
//打印结果
System.out.println(userList);
//mybatis执行更新操作 提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
@Test
//插入操作
public void insert() throws IOException {
//获得核心配置文件
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得session工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//获得session回话对象
SqlSession sqlSession = sqlSessionFactory.openSession();
User user = new User();
user.setUsername("李四");
user.setPassword("1234");
//执行sql语句
int res = sqlSession.insert("userMapper.insert",user);
if(res > 0){
System.out.println("执行成功!影响行数:"+res);
}
//mybatis执行更新操作 提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
@Test
//更新操作
public void update() throws IOException {
//获得核心配置文件
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得session工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//获得session回话对象
SqlSession sqlSession = sqlSessionFactory.openSession();
User user = new User();
user.setId(2);
user.setUsername("lucy");
user.setPassword("1234");
//执行sql语句
int res = sqlSession.update("userMapper.update",user);
if(res > 0){
System.out.println("执行成功!影响行数:"+res);
}
//mybatis执行更新操作 提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
}
6、Mybatis的Dao层实现
6、1代理开发方式
采用 Mybatis 的代理开发方式实现 DAO 层的开发,这种方式是我们后面进入企业的主流。 Mapper 接口开发方法只需要程序员编写Mapper 接口(相当于Dao 接口),由Mybatis 框架根据接口定义创建接 口的动态代理对象,代理对象的方法体同上边Dao接口实现类方法。 Mapper 接口开发需要遵循以下规范: 1、 Mapper.xml文件中的namespace与mapper接口的全限定名相同 2、 Mapper接口方法名和Mapper.xml中定义的每个statement的id相同 3、 Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql的parameterType的类型相同 4、 Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同
编写UserMapper接口(遵循以下规范)
6、2 测试代理方式public class servicetest {
public static void main(String[] args) throws Exception{
//
//获得核心配置文件
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得session工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//获得session回话对象
SqlSession sqlSession = sqlSessionFactory.openSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
List userList = mapper.findAll();
System.out.println(userList);
User user = mapper.findById(2);
System.out.println(user);
}
}
总结:MyBatis的Dao层实现的两种方式
-
手动对Dao进行实现:传统开发方式
-
代理方式对Dao进行实现: UserMapper userMapper = sqlSession.getMapper(UserMapper.class)



