Mybatis-Day1
黑马教程学习笔记
第一天:mybatis入门 ;mybatis的概述 ;mybatis的环境搭建 ;mybatis入门案例 ;自定义mybatis框架
1、三层架构
表现层: 是用于展示数据的
业务层:是处理业务需求
持久层:是和数据库交互的
2、持久层技术解决方案
JDBC:Connection PreparedStatement ResultSet
Spring:jdbcTemplate
Apache:DBUtils
3、Mybatis概述
持久层框架,封装细节,只关注sql语句
ORM思想(Object Relational Mapping)对象关系映射;将数据库表与实体类及其属性对应起来
4、入门案例
(一)配置文件方式
环境搭建:
1.创建maven工程
2.创建实体类和dao接口
3.创建主配置文件SqlMapConfig.xml
4.创建映射配置文件IUserDao.xml
注意:
1.Mybatis中,接口叫做Mapper,IUserDao与IUserMapper一样
2.resources中包创建是三级目录时,要一级一级创建
3.mybatis的映射配置文件位置要与到接口包结构相同
4.映射配置文件的Mapper标签namespace属性值必须是dao接口全限定类名
5.映射配置文件的操作配置(select),id属性值必须是dao接口方法名
maven导入jar包:
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.12</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
</dependency>
</dependencies>
主配置文件SqlMapConfig.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<!-- mybatis的主配置文件 -->
<configuration>
<!-- 配置环境 -->
<environments default="mysql">
<!-- 配置mysql的环境-->
<environment id="mysql">
<!-- 配置事务的类型-->
<transactionManager type="JDBC"></transactionManager>
<!-- 配置数据源(连接池) -->
<dataSource type="POOLED">
<!-- 配置连接数据库的4个基本信息 -->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/eesy"/>
<property name="username" value="root"/>
<property name="password" value="123"/>
</dataSource>
</environment>
</environments>
<!-- 指定映射配置文件的位置,映射配置文件指的是每个dao独立的配置文件 -->
<mappers>
<mapper resource="com/mys/dao/IUserDao.xml"/>
</mappers>
</configuration>
映射配置文件IUserDao.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="com.mys.dao.IUserDao">
<!--配置查询所有-->
<select id="findAll" resultType="com.mys.domain.User">
select * from user
</select>
</mapper>
步骤:
注意:配置映射中告知mybatis封装的实体类
配置方式:指定实体类全限定类名
(二)注解方式
1.移除IUserDao.xml,在dao接口上使用@Select注解,并指定sql语句
2.在SqlMapConfig.xml中的mapper配置,使用class属性指定dao接口全限定类名
SqlMapConfig.xml:
<!--指定映射配置文件的位置,映射配置文件指的是每个dao独立的配置文件-->
<!--<mappers>-->
<!--<mapper resource="com/mys/dao/IUserDao.xml"/>-->
<!--</mappers>-->
<!--使用注解配置,使用class属性指定被注解的全限定类-->
<mappers>
<mapper class="com.mys.dao.IUserDao"/>
</mappers>
IUserDao:
@Select("select * from user")
List<User> findAll();
注意:通常实际开发中不写dao实现类的方式,但mybatis支持写dao
5、自定义mybatis
在使用代理dao实现CRUD时,做两件事:
1.创建代理对象
2.在代理对象中调用selectList
/**
* 使用类加载器读取配置文件的类
*/
public class Resources {
/**
* 根据传入的参数,获取一个字节输入流
* @param filePath
* @return
*/
public static InputStream getSourceAsStream(String filePath) {
//拿到字节码->获取字节码类加载器->根据类加载器读取配置文件
return Resources.class.getClassLoader().getResourceAsStream(filePath);
}
}
自定义mybatis框架结构分析(引用黑马)
补充知识:反射、动态代理、工厂模式