0


Mybatis(一):环境搭建

Mybatis(一):环境搭建



前言

本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主!也许一个人独行,可以走的很快,但是一群人结伴而行,才能走的更远!

一、MyBatis简介

1、MyBatis历史

MyBatis

最初是

Apache

的一个开源项目

iBatis

, 2010年6月这个项目由

Apache Software Foundation

迁移到了

Google Code

。随着开发团队转投

Google Code

旗下,

iBatis3.x

正式更名为

MyBatis

。代码于2013年11月迁移到

Github

iBatis

一词来源于“

internet

”和“

abatis

”的组合,是一个基于

Java

的持久层框架。

iBatis

提供的持久层框架包括

SQL Maps

Data Access Objects(DAO

)。

2、MyBatis特性

MyBatis

是支持定制化

SQL

、存储过程以及高级映射的优秀的持久层框架

MyBatis

避免了几乎所有的

JDBC

代码和手动设置参数以及获取结果集

MyBatis

可以使用简单的XML或注解用于配置和原始映射,将接口和

Java

POJO

Plain Old Java Objects

,普通的

Java

对象)映射成数据库中的记录

MyBatis

是一个 半自动的

ORM

ObjectRelation Mapping

)框架

3、MyBatis下载

点击跳转下载页面
在这里插入图片描述

4、和其它持久化层技术对比

⭕ **

JDBC

**

SQL

夹杂在

Java

代码中耦合度高,导致硬编码内伤
● 维护不易且实际开发需求中

SQL

有变化,频繁修改的情况多见
● 代码冗长,开发效率低

⭕ **

Hibernate

** 和 **

JPA

**
● 操作简便,开发效率高
● 程序中的长难复杂

SQL

需要绕过框架
● 内部自动生产的

SQL

,不容易做特殊优化
● 基于全映射的全自动框架,大量字段的

POJO

进行部分映射时比较困难
● 反射操作太多,导致数据库性能下降

⭕ **

MyBatis

**

●轻量级,性能出色

SQL

Java

编码分开,功能边界清晰

Java

代码专注业务、

SQL

语句专注数据
●开发效率稍逊于

HIbernate

,但是完全能够接受

二、搭建MyBatis

1、开发环境

IDEA

idea 2019.2

⭕ 构建工具:

maven 3.5.4

MySQL

版本:

MySQL 5.7

MyBatis

版本:

MyBatis 3.5.7

2、创建maven工程

2.1 打包方式:jar

2.2 引入依赖

<dependencies><!-- Mybatis核心 --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.7</version></dependency><!-- junit测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- MySQL驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.3</version></dependency></dependencies>

3、创建MyBatis的核心配置文件

⭕ 习惯上命名为

mybatis-config.xml

,这个文件名仅仅只是建议,并非强制要求。
⭕ 将来整合

Spring

之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。
⭕ 核心配置文件主要用于配置连接数据库的环境以及

MyBatis

的全局配置信息

mybatis-config.xml

:

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPEconfigurationPUBLIC"-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration><!--设置连接数据库的环境--><environmentsdefault="development"><environmentid="development"><transactionManagertype="JDBC"/><dataSourcetype="POOLED"><propertyname="driver"value="com.mysql.jdbc.Driver"/><propertyname="url"value="jdbc:mysql://localhost:3306/MyBatis"/><propertyname="username"value="root"/><propertyname="password"value="0523"/></dataSource></environment></environments><!--引入映射文件--><mappers><mapperresource="mappers/UserMapper.xml"/></mappers></configuration>

4、创建mapper接口

MyBatis

中的

mapper

接口相当于以前的

dao

,我们可以理解为与之前我们学习的

DAO

类相呼应。但是区别在于,

mapper

仅仅是接口,我们不需要提供它的实现类。

publicinterfaceUserMapper{/**
  * 添加用户信息
  */intinsertUser();}

5、创建MyBatis的映射文件

⭕ 相关概念:

ORM(Object Relationship Mapping)

对象关系映射。
● 对象:

Java

的实体类对象
● 关系:关系型数据库
● 映射:二者之间的对应关系

⭕ 一张数据库的表对应一个

DAO

类,即一张表对应一个

Mapper

接口,一个

Mapper

接口对应一个映射文件,所有有此对应关系:
一张数据库表

<===>

一个实体类

<===>

一个

DAO

/Mapper

接口

<===>

一个映射文件

Java概念数据库概念类表属性字段/列对象记录/行

⭕ 映射文件的命名规则: 表所对应的实体类的类名+

Mapper.xml

例如:表

t_user

,映射的实体类为

User

,所对应的映射文件为

UserMapper.xml

因此一个映射文件对应一个实体类,对应一张表的操作

MyBatis

映射文件用于编写

SQL

,访问以及操作表中的数据

MyBatis

映射文件存放的位置是

src/main/resources/mappers

目录下

MyBatis

中可以面向接口操作数据,要保证两个一致:

mapper

接口的全类名和映射文件的命名空间(

namespace

)保持一致

mapper

接口中方法的方法名和映射文件中编写

SQL

的标签的id属性保持一致

User

类:

publicclassUser{privateInteger id;privateString username;privateString password;privateInteger age;privateString sex;privateString email;...}
UserMapper.java

publicinterfaceUserMapper{/**
     * MyBatis面向接口编程的两个一致:
     * 1.映射文件的 namespace 要和 mapper 接口的全类名保持一致
     * 2.映射文件中的SQL语句的id要和 mapper 接口中的方法名保持一致
     *//**
     *添加用户信息
     */intinsertUser();}
UserMapper.xml

:

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPEmapperPUBLIC"-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mappernamespace="com.ir.mybatis.mapper.UserMapper"><!--int insertUser();--><insertid="insertUser">
                insert into t_user values(null,'张三','123',23,'女')
          </insert></mapper>

6、通过junit测试功能

测试:

packagecom.ir.mybaits.test;importcom.ir.mybatis.mapper.UserMapper;importorg.apache.ibatis.io.Resources;importorg.apache.ibatis.session.SqlSession;importorg.apache.ibatis.session.SqlSessionFactory;importorg.apache.ibatis.session.SqlSessionFactoryBuilder;importorg.junit.Test;importjava.io.IOException;importjava.io.InputStream;/**
 * @author shkstart
 * @create 2022-07-02 15:36
 */publicclassMyBatisTest{@TestpublicvoidtestMyBatis()throwsIOException{//加载核心配置文件---->制作建筑图纸InputStream is =Resources.getResourceAsStream("mybatis-config.xml");//获取SqlSessionFactoryBuilder---->招募工人SqlSessionFactoryBuilder sqlSessionFactoryBuilder =newSqlSessionFactoryBuilder();//通过核心配置文件所对应的字节输入流创建工厂类SqlSessionFactory,生产SqlSession对象---->图纸给工人,去造工厂SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);//创建SqlSession对象,此时通过SqlSession对象所操作的sql都必须手动提交或回滚事务---->工厂生产出产品SqlSession sqlSession = sqlSessionFactory.openSession();//调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配元素文件,通过调用的方法名匹配映射文件中的SQL标签,并执行标签中的SQL语句---->产品的功能UserMapper mapper = sqlSession.getMapper(UserMapper.class);//测试int result = mapper.insertUser();//提交事务
        sqlSession.commit();System.out.println("result:"+result);}}

知识点:

SqlSession

:代表

Java

程序和数据库之间的会话。(

HttpSession

Java

程序和浏览器之间的会话)

SqlSessionFactory

:是“生产”

SqlSession

的“工厂”。

⭕工厂模式:如果创建某一个对象,使用的过程基本固定,那么我们就可以把创建这个对象的相关代码封装到一个“工厂类”中,以后都使用这个工厂类来“生产”我们需要的对象。

7、优化

7.1 优化一:自动提交事务

SqlSession

默认不自动提交事务,若需要自动提交事务,可以使用

SqlSessionFactory.openSession(true);

7.2 优化二:加入log4j日志功能

(1)加入依赖

<!-- log4j日志 --><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency>

(2)加入

log4j

的配置文件

log4j

的配置文件名为

log4j.xml

,存放的位置是

src/main/resources

目录下

⭕日志的级别:

FATAL

(致命)>

ERROR

(错误)>

WARN

(警告)>

INFO

(信息)>

DEBUG

(调试)
从左到右打印的内容越来越详细

log4j.xml

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPElog4j:configurationSYSTEM"log4j.dtd"><log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/"><appendername="STDOUT"class="org.apache.log4j.ConsoleAppender"><paramname="Encoding"value="UTF-8"/><layoutclass="org.apache.log4j.PatternLayout"><paramname="ConversionPattern"value="%-5p %d{MM-dd HH:mm:ss,SSS}
%m (%F:%L) \n"/></layout></appender><loggername="java.sql"><levelvalue="debug"/></logger><loggername="org.apache.ibatis"><levelvalue="info"/></logger><root><levelvalue="debug"/><appender-refref="STDOUT"/></root></log4j:configuration>

三、核心配置文件详解

jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis
jdbc.username=root
jdbc.password=0523   
mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPEconfigurationPUBLIC"-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration><!--
            MyBatis核心配置文件中,标签的顺序:
            properties?,settings?,typeAliases?,typeHandlers?,
            objectFactory?,objectWrapperFactory?,reflectorFactory?,
            plugins?,environments?,databaseIdProvider?,mappers?
        --><!--引入properties文件--><propertiesresource="jdbc.properties"/><!--设置类型别名--><typeAliases><!--
                    typeAlias:设置某个类型的别名
                    属性:
                        type:设置需要设置别名的类型
                        alias:设置某个类型的别名,若不设置该属性,那么该类型拥有默认的别名,即类名且不区分大小写
                --><!--<typeAlias type="com.atguigu.mybatis.pojo.User"></typeAlias>--><!--以包为单位,将包下所有的类型设置默认的类型别名,即类名且不区分大小写--><packagename="com.ir.mybatis.pojo"/></typeAliases><!--
            environments:配置多个连接数据库的环境
            属性:
                default:设置默认使用的环境的id
        --><environmentsdefault="development"><!--
                    environment:配置某个具体的环境
                    属性:
                        id:表示连接数据库的环境的唯一标识,不能重复
                --><environmentid="development"><!--
                            transactionManager:设置事务管理方式
                            属性:
                                type="JDBC|MANAGED"
                                JDBC:表示当前环境中,执行SQL时,使用的是JDBC中原生的事务管理方式,事务的提交或回滚需要手动处理
                                MANAGED:被管理,例如Spring
                        --><transactionManagertype="JDBC"/><!--
                            dataSource:配置数据源
                            属性:
                                type:设置数据源的类型
                                type="POOLED|UNPOOLED|JNDI"
                                POOLED:表示使用数据库连接池缓存数据库连接
                                UNPOOLED:表示不使用数据库连接池
                                JNDI:表示使用上下文中的数据源
                        --><dataSourcetype="POOLED"><!--设置连接数据库的驱动--><propertyname="driver"value="${jdbc.driver}"/><!--设置连接数据库的连接地址--><propertyname="url"value="${jdbc.url}"/><!--设置连接数据库的用户名--><propertyname="username"value="${jdbc.username}"/><!--设置连接数据库的密码--><propertyname="password"value="${jdbc.password}"/></dataSource></environment><environmentid="test"><transactionManagertype="JDBC"/><dataSourcetype="POOLED"><propertyname="driver"value="com.mysql.jdbc.Driver"/><propertyname="url"value="jdbc:mysql://localhost:3306/mybatis"/><propertyname="username"value="root"/><propertyname="password"value="123456"/></dataSource></environment></environments><!--引入映射文件--><mappers><!--<mapper resource="mappers/UserMapper.xml"/>--><!--
                    以包为单位引入映射文件
                    要求:
                    1、mapper接口所在的包要和映射文件所在的包一致
                    2、mapper接口要和映射文件的名字一致:即UserMapper与UserMapper.xml
                --><packagename="com.ir.mybatis.mapper"/></mappers></configuration>

注意:

⭕ 核心配置文件中的标签必须按照固定的顺序:

  1. properties
  2. settings
  3. typeAliases
  4. typeHandlers
  5. objectFactory
  6. objectWrapperFactory
  7. reflectorFactory
  8. plugins
  9. environments
  10. databaseIdProvider
  11. mappers

<typeAliases> </typeAliases>

支持以包为单位来设置默认类型

<mappers></mappers>

● 支持以包为单位来引入映射文件
● 在

resources

下创建包名时,由于

resources

下为普通文件,所以并不可以以"

.

“为分隔符的方式来创建嵌套的包名,而应该用以”

/

"的方式来创建

在这里插入图片描述

四、idea中设置文件模板

1、在idea中设置核心配置文件的模板

mybatis-config

官方文档模板:

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPEconfigurationPUBLIC"-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration><environmentsdefault="development"><environmentid="development"><transactionManagertype="JDBC"/><dataSourcetype="POOLED"><propertyname="driver"value="${driver}"/><propertyname="url"value="${url}"/><propertyname="username"value="${username}"/><propertyname="password"value="${password}"/></dataSource></environment></environments><mappers><mapperresource="org/mybatis/example/BlogMapper.xml"/></mappers></configuration>

⭕ 设置:

在这里插入图片描述

2、在idea中设置映射文件的模板

mybatis-mapper

官方文档模板:

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPEmapperPUBLIC"-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mappernamespace="org.mybatis.example.BlogMapper"><selectid="selectBlog"resultType="Blog">
        select * from Blog where id = #{id}
    </select></mapper>

⭕ 设置:
在这里插入图片描述
在这里插入图片描述


本文转载自: https://blog.csdn.net/weixin_52533007/article/details/125620656
版权归原作者 _GGBond_ 所有, 如有侵权,请联系我们删除。

“Mybatis(一):环境搭建”的评论:

还没有评论