Mybatis-Day1

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框架结构分析(引用黑马)
在这里插入图片描述
补充知识:反射、动态代理、工厂模式

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值