第七Mybatis --01

Mybatis概述:

Mybatis是持久层框架

Mybatis内部封装的jdbc繁琐的操作

使用Mybatis时我们只需要关注sql语句即可

ORM思想: 对象关系映射(查询结果跟实体字段的对应关系—实体的属性名称要和数据库表的字段名称保持一致)

1.Mybatis简介

1.1原始jdbc操作(查询数据)在这里插入图片描述
1.2原始jdbc操作(插入数据)

在这里插入图片描述

1.3 原始jdbc操作的分析

原始jdbc开发存在的问题如下:

①数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能

②sql 语句在代码中硬编码,造成代码不易维护,实际应用 sql 变化的可能较大,sql 变动需要改变java代码。

③查询操作时,需要手动将结果集中的数据手动封装到实体中。插入操作时,需要手动将实体的数据设置到sql语句的占位符位置

应对上述问题给出的解决方案:

①使用数据库连接池初始化连接资源

②将sql语句抽取到xml配置文件中

③使用反射、内省等底层技术,自动将实体与表进行属性与字段的自动映射

2.Mybatis的快速入门

2.1MyBatis官网地址:http://www.mybatis.org/mybatis-3/

MyBatis开发步骤:

①添加MyBatis的坐标

②创建user数据表

③编写User实体类

④编写映射文件UserMapper.xml

⑤编写核心文件SqlMapConfig.xml

⑥编写测试类

2.2 环境搭建

1)导入MyBatis的坐标和其他相关坐标

<!--mybatis坐标-->
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.4.5</version>
</dependency>
<!--mysql驱动坐标-->
<dependency>    
    <groupId>mysql</groupId>   
    <artifactId>mysql-connector-java</artifactId>    
    <version>5.1.6</version>    
    <scope>runtime</scope>
</dependency>
<!--单元测试坐标-->
<dependency>    
    <groupId>junit</groupId>    
    <artifactId>junit</artifactId>    
    <version>4.12</version>    
    <scope>test</scope>
</dependency>
<!--日志坐标-->
<dependency>    
    <groupId>log4j</groupId>    
    <artifactId>log4j</artifactId>    
    <version>1.2.12</version>
</dependency>
  1. 创建user数据表
    在这里插入图片描述
  2. 编写User实体
public class User {    
	private int id;    
	private String username;    
	private String password;
    //省略get个set方法
}

4)编写UserMapper映射文件

<?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="userMapper">    
	<select id="findAll" resultType="com.itheima.domain.User">        
		select * from User    
	</select>
</mapper>
  1. 编写MyBatis核心文件
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN“ "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>    
	<environments default="development">        
		<environment id="development">            
			<transactionManager type="JDBC"/>            
			<dataSource type="POOLED">                
				<property name="driver" value="com.mysql.jdbc.Driver"/>
				<property name="url" value="jdbc:mysql:///test"/>                
				<property name="username" value="root"/>
				<property name="password" value="root"/>            
			</dataSource>        
		</environment>    
	</environments>    
	
	<mappers> 
		<mapper resource="com/itheima/mapper/UserMapper.xml"/> 
	</mappers>
</configuration>

2.3 编写测试代码
//加载核心配置文件
InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml");
//获得sqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new            
                           SqlSessionFactoryBuilder().build(resourceAsStream);
//获得sqlSession对象
SqlSession sqlSession = sqlSessionFactory.openSession();
//执行sql语句
List<User> userList = sqlSession.selectList("userMapper.findAll");
//打印结果
System.out.println(userList);
//释放资源
sqlSession.close();

3. MyBatis的映射文件概述

在这里插入图片描述

4. MyBatis的增删改查操作

4.1 MyBatis的插入数据操作

1)编写UserMapper映射文件

<mapper namespace="userMapper">    
	<insert id="add" parameterType="com.itheima.domain.User">        
		insert into user values(#{id},#{username},#{password})    
	</insert>
</mapper>

2)编写插入实体User的代码

InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new 
                        SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
int insert = sqlSession.insert("userMapper.add", user);
System.out.println(insert);
//提交事务
sqlSession.commit();
sqlSession.close();

3)插入操作注意问题

• 插入语句使用insert标签

• 在映射文件中使用parameterType属性指定要插入的数据类型

•Sql语句中使用#{实体属性名}方式引用实体中的属性值

•插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);

•插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()

4.2 MyBatis的修改数据操作

1)编写UserMapper映射文件

<mapper namespace="userMapper">
    <update id="update" parameterType="com.itheima.domain.User">
        update user set username=#{username},password=#{password} where id=#{id}
    </update>
</mapper>

2)编写修改实体User的代码

InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
int update = sqlSession.update("userMapper.update", user);
System.out.println(update);
sqlSession.commit();
sqlSession.close();

3)修改操作注意问题

• 修改语句使用update标签

• 修改操作使用的API是sqlSession.update(“命名空间.id”,实体对象);

4.3 MyBatis的删除数据操作

1)编写UserMapper映射文件

<mapper namespace="userMapper">
    <delete id="delete" parameterType="java.lang.Integer">
        delete from user where id=#{id}
    </delete>
</mapper>

2)编写删除数据的代码

InputStream resourceAsStream = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
int delete = sqlSession.delete("userMapper.delete",3);
System.out.println(delete);
sqlSession.commit();
sqlSession.close();

3)删除操作注意问题

• 删除语句使用delete标签

•Sql语句中使用#{任意字符串}方式引用传递的单个参数

•删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);

===================================================================================


增删改查映射配置与API:
查询数据: List<User> userList = sqlSession.selectList("userMapper.findAll");
    <select id="findAll" resultType="com.itheima.domain.User">
        select * from User
    </select>
添加数据: sqlSession.insert("userMapper.add", user);
    <insert id="add" parameterType="com.itheima.domain.User">
        insert into user values(#{id},#{username},#{password})
    </insert>
修改数据: sqlSession.update("userMapper.update", user);
    <update id="update" parameterType="com.itheima.domain.User">
        update user set username=#{username},password=#{password} where id=#{id}
    </update>
删除数据:sqlSession.delete("userMapper.delete",3);
    <delete id="delete" parameterType="java.lang.Integer">
        delete from user where id=#{id}
    </delete>

5. MyBatis核心配置文件概述

5.1 MyBatis核心配置文件层级关系

在这里插入图片描述

5.2 MyBatis常用配置解析

1)environments标签

数据库环境的配置,支持多环境配置
在这里插入图片描述
2)mapper标签

该标签的作用是加载映射的,加载方式有如下几种:

•使用相对于类路径的资源引用,例如:

•使用完全限定资源定位符(URL),例如:

•使用映射器接口实现类的完全限定类名,例如:

•将包内的映射器接口实现全部注册为映射器,例如:

<!-- 配置映射文件的路径 -->
    <mappers>
        <mapper resource="com/itheima/mapper/UserMapper.xml"/>
        <mapper resource="com/itheima/mapper/StudentMapper.xml"/>
    </mappers>

3)Properties标签

实际开发中,习惯将数据源的配置信息单独抽取成一个properties文件,该标签可以加载额外配置的properties文件

<!-- 加载properties配置文件 -->
    <properties resource="jdbc.properties"></properties>

4)typeAliases标签

类型别名是为Java 类型设置一个短的名字。原来的类型名称配置如下

 <typeAliases>
        <!-- 给类起别名 -->
        <!--<typeAlias type="com.itheima.domain.User" alias="user"></typeAlias>-->
        <!-- 给包下所有的类起别名,别名为类名称(不区分大小写) -->
        <package name="com.itheima.domain"></package>
    </typeAliases>

6.MyBatis相应API

6.1 SqlSession工厂构建器SqlSessionFactoryBuilder

常用API:SqlSessionFactory build(InputStream inputStream)

通过加载mybatis的核心文件的输入流的形式构建一个SqlSessionFactory对象

String resource = "org/mybatis/builder/mybatis-config.xml"; 
InputStream inputStream = Resources.getResourceAsStream(resource); 
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); 
SqlSessionFactory factory = builder.build(inputStream);
6.2 SqlSession工厂对象SqlSessionFactory

SqlSessionFactory 有多个个方法创建SqlSession 实例。常用的有如下两个:
在这里插入图片描述

6.3 SqlSession会话对象

SqlSession 实例在 MyBatis 中是非常强大的一个类。在这里你会看到所有执行语句、提交或回滚事务和获取映射器实例的方法。

执行语句的方法主要有:

<T> T selectOne(String statement, Object parameter) 
<E> List<E> selectList(String statement, Object parameter) 
int insert(String statement, Object parameter) 
int update(String statement, Object parameter) 
int delete(String statement, Object parameter)

操作事务的方法主要有:

void commit()  
void rollback() 

7.Mybatis的执行流程

配置文件:用来存放配置信息,解耦合。
java代码的执行需要依赖配置文件中的信息,但是java代码不能直接使用配置文件中的配置信息,所有要先解析。
遇到配置文件,首先解析配置文件,把配置文件中的信息存放到java实体中。
   //前提,jia包,核心配置文件,映射文件 均已就绪
   //(1).加载核心配置文件(得到核心配置文件的流信息)
    InputStream is = Resources.getResourceAsStream("sqlMapConfig.xml");
    //(2).解析配置文件
	//2.1
    SqlSessionFactoryBuilder sfb = new SqlSessionFactoryBuilder()
    //2.2
    SqlSessionFactory  sqlSessionFactory=  sfb.build(is);
    //(3).创建sqlSession对象(建立java代码与数据库的回话,操作数据库)
    SqlSession sqlSession =  sfb.openSession();
    //(4).执行sql
    List<User> list = sqlSession.selectList("userMapper.findAll");
    for (User user : list) {
        System.out.println(user);
    }
    //(5).关闭连接
    sqlSession.close();
1),一执行,就得到了核心配置文件的输入流信息。

(2),一执行传入一个配置文件的输入流,
SqlSessionFactoryBuilder
public SqlSessionFactory build(InputStream is){
  //1.解析配置文件(核心配置文件,映射文件集)
    //1.1创建对象,存放配置信息
  	Configuration conf = new Configuration();
    //1.2:解析核心配置文件得到连接数据库的基本信息,存入conf对象中
    //1.3:解析核心配置文件得到映射文件路径集合,遍历路径集合解析每一个映射文件,为每一个映射文件的每一个标签创建一个Mapper对象,存放标签上的sql语句和返回值类型或者请求参数类型.将得到的Mapper实体存放到配置类的map集合中 key是 映射文件的命名空间.每个标签的id,value是对应的mapper对象。
   Map<String "命名空间.id",Mapper,mapper>
       
当执行到这儿的时候已经把所有的配置文件转成一个实体bean(Configuration)配置文件中的一切,都已存放到Configuration中。需要什么直接从这个实体的配置类 中获取就可以了
       
  //2.创建SqlSessionFactory对象,并将配置类传入
  return new SqlSessionFactory(conf );
}
 SqlSessionFactory:
     Configuration conf;
     public SqlSessionFactory(Configuration conf){
      this.conf = conf;
     }
    public SqlSession  openSession(){
       return new DefaultSqlSession(conf);
    }
//sqlSession 是接口,new的是 DefaultSqlSession 实现类。
SqlSession  : 接口
 selectList(String 标识,Object ...);
 selectOne();
 insert(...);
 update();
 ..... ..... ..... ..... ..... ..... ..... ..... ..... ..... ..... ..... ..... ..... .....
DefaultSqlSession 实现 SqlSession
Configuration conf; // 核心配置类
public DefaultSqlSession (Configuration conf){
   this.conf = conf;
}
 selectList(String id,Object ...){//(这个string 的id  就是 "命名空间.id")
   //注册驱动
   //获取连接
   //获取语句执行者
  // 获取sql语句 (从核心配置类中读取)
 Mapper mapper = conf.map.getkey("id");
String sql = mapper.getSql(); 
 // 执行
 // 封装结果集
}
 selectOne();
 insert(...);
 update();

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值