day04 Maven&MyBatis

一、Maven

1.1 概述

Maven是专门用于管理和构建Java项目的工具,它的主要功能有:

  • 提供了一套标准化的项目结构

  • 提供了一套标准化的构建流程(编译,测试,打包,发布……)

  • 提供了一套依赖管理机制

标准化的构建流程:

 如上图所示我们开发了一套系统,代码需要进行编译、测试、打包、发布,这些操作如果需要反复进行就显得特别麻烦,而Maven提供了一套简单的命令来完成项目构建。

依赖管理:

使用标准的 坐标 配置来管理各种依赖,只需要简单的配置就可以完成依赖管理。

1.2 仓库

仓库分类:

当项目中使用坐标引入对应依赖jar包后,首先会查找本地仓库中是否有对应的jar包:

  • 如果有,则在项目直接引用;

  • 如果没有,则去远程仓库中下载对应的jar包到本地仓库。

  • 如果远程仓库没有则去中央仓库找

jar包的查找顺序则变为:

本地仓库 --> 远程仓库--> 中央仓库

1.3 Maven基本使用

1.3.1 Maven 常用命令

  • compile :编译

  • clean:清理

  • package:打包

  • test:测试

  • install:安装

1. compile :编译

从阿里云下载编译需要的插件的jar包,

在本地仓库也能看到下载好的插件 在项目下会生成一个 target 目录

同时在项目下会出现一个 target 目录,编译后的字节码文件就放在该目录下

2. clean:清理

从阿里云下载清理需要的插件jar包

删除项目下的 target 目录

3. package:打包

从阿里云下载打包需要的插件jar包

在项目的 terget 目录下有一个jar包(将当前项目打成的jar包)

4. test:测试

该命令会执行所有的测试代码

5. install:安装

该命令会将当前项目打成jar包,并安装到本地仓库

1.4 Maven 生命周期

Maven 对项目构建的生命周期划分为3套:

  • clean :清理工作。

  • default :核心工作,例如编译,测试,打包,安装等。

  • site : 产生报告,发布站点等。这套声明周期一般不会使用。

同一套生命周期内,执行后边的命令,前面的所有命令会自动执行

如: 当我们执行 install(安装)命令时,它会自动先执行 compile命令,再执行 test 命令,再执行 package 命令,最后执行 install 命令。

1.4 Maven 坐标详解

1.4.1 概述

  • Maven 中的坐标是资源的唯一标识

  • 使用坐标来定义项目或引入项目中需要的依赖

1.4.2 Maven 坐标主要组成

  • groupId:定义当前Maven项目隶属组织名称(通常是域名反写,例如:com.itheima)

  • artifactId:定义当前Maven项目名称(通常是模块名称,例如 order-service、goods-service)

  • version:定义当前项目版本号

我们的项目如果被其他的项目依赖时,也是需要坐标来引入的。

1.5 依赖管理

1.5.1 使用坐标引入jar包

使用坐标引入jar包的步骤:

  • 在项目的 pom.xml 中编写 <dependencies> 标签

  • 在 <dependencies> 标签中 使用 <dependency> 引入坐标

  • 定义坐标的 groupId,artifactId,version

  • 点击刷新按钮,使坐标生效

具体的坐标我们可以到如下网站进行搜索

1.5.2 依赖范围

通过设置坐标的依赖范围(scope),可以设置 对应jar包的作用范围:编译环境、测试环境、运行环境。

如下图所示给 junit 依赖通过 scope 标签指定依赖的作用范围。 那么这个依赖就只能作用在测试环境,其他环境下不能使用。

依赖范围编译classpath测试classpath运行classpath例子
compileYYYlogback
test-Y-Junit
providedYY-servlet-api
runtime-YYjdbc驱动
systemYY-存储在本地的jar包
  • compile :作用于编译环境、测试环境、运行环境。

  • test : 作用于测试环境。典型的就是Junit坐标,以后使用Junit时,都会将scope指定为该值

  • provided :作用于编译环境、测试环境。

  • runtime : 作用于测试环境、运行环境。jdbc驱动一般将 scope 设置为该值,当然不设置也没有任何问题

注意:

  • 如果引入坐标不指定 scope 标签时,默认就是 compile 值。以后大部分jar包都是使用默认值。

二、Mybatis

2.1 Mybatis概述

持久层:

  • 负责将数据到保存到数据库的那一层代码。

    以后开发我们会将操作数据库的Java代码作为持久层。而Mybatis就是对jdbc代码进行了封装。

  • JavaEE三层架构:表现层、业务层、持久层

框架:

  • 框架就是一个半成品软件,是一套可重用的、通用的、软件基础代码模型

  • 在框架的基础之上构建软件编写更加高效、规范、通用、可扩展

2.2 JDBC 缺点

  • 1. 硬编码

    •  注册驱动、获取连接

      上图标1的代码有很多字符串,而这些是连接数据库的四个基本信息,以后如果要将Mysql数据库换成其他的关系型数据库的话,这四个地方都需要修改,如果放在此处就意味着要修改我们的源代码。

    • SQL语句

      上图标2的代码。如果表结构发生变化,SQL语句就要进行更改。这也不方便后期的维护。

  • 2. 操作繁琐

    • 手动设置参数

    • 手动封装结果集

      上图标4的代码是对查询到的数据进行封装,而这部分代码是没有什么技术含量,而且特别耗费时间的。

2.3 Mybatis 优化

  • 硬编码可以配置到配置文件

  • 操作繁琐的地方mybatis都自动完成

2.2 Mybatis快速入门

需求:查询user表中所有的数据

1. 创建user表,添加数据

2. 创建模块,导入坐标

在创建好的模块中的 pom.xml 配置文件中添加依赖的坐标

<dependencies>
<!--mybatis 依赖-->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.5</version>
    </dependency>

<!--mysql 驱动-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.46</version>
    </dependency>

<!--junit 单元测试-->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13</version>
        <scope>test</scope>
    </dependency>

<!-- 添加slf4j日志api -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.20</version>
    </dependency>

<!-- 添加logback-classic依赖 -->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.2.3</version>
    </dependency>

<!-- 添加logback-core依赖 -->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
        <version>1.2.3</version>
    </dependency>
</dependencies>


注意:需要在项目的 resources 目录下创建logback的配置文件

3. 编写 MyBatis 核心配置文件 -- > 替换连接信息 解决硬编码问题

在模块下的 resources 目录下创建mybatis的配置文件 mybatis-config.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">
 <configuration>
 ​
     <typeAliases>
         <package name="com.itheima.pojo"/>
     </typeAliases>
     
     <!--
     environments:配置数据库连接环境信息。可以配置多个environment,通过default属性切换不同的environment
     -->
     <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:///mybatis?useSSL=false"/>
                 <property name="username" value="root"/>
                 <property name="password" value="1234"/>
             </dataSource>
         </environment>
 ​
         <environment id="test">
             <transactionManager type="JDBC"/>
             <dataSource type="POOLED">

                 <!--数据库连接信息-->
                 <property name="driver" value="com.mysql.jdbc.Driver"/>
                 <property name="url" value="jdbc:mysql:///mybatis?useSSL=false"/>
                 <property name="username" value="root"/>
                 <property name="password" value="1234"/>
             </dataSource>
         </environment>
     </environments>
     <mappers>

        <!--加载sql映射文件-->
        <mapper resource="UserMapper.xml"/>
     </mappers>
 </configuration>

4. 编写 SQL 映射文件 --> 统一管理sql语句,解决硬编码问题

在模块的 resources 目录下创建映射配置文件 UserMapper.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="test">
     <select id="selectAll" resultType="com.itheima.pojo.User">
         select * from tb_user;
     </select>
 </mapper>

5. 在 pojo 包下创建 User类

 public class User {
     private int id;
     private String username;
     private String password;
     private String gender;
     private String addr;
     
     //省略了 setter 和 getter
 }

6. 编写 MybatisDemo 测试类

public class MyBatisDemo {
    public static void main(String[] args) throws IOException {

    //1. 加载mybatis的核心配置文件,获取 SqlSessionFactory
    String resource = "mybatis-config.xml";
    InputStream inputStream = Resources.getResourceAsStream(resource);
    SqlSessionFactory sqlSessionFactory = new
    SqlSessionFactoryBuilder().build(inputStream);

    //2. 获取SqlSession对象,用它来执行sql
    SqlSession sqlSession = sqlSessionFactory.openSession();
    
    //3. 执行sql
    List<User> users = sqlSession.selectList("test.selectAll"); 
    //参数是一个字符串,该字符串必须是映射配置文件的namespace.id

    System.out.println(users);

    //4. 释放资源
    sqlSession.close();

    }
}

2.3 Mapper代理开发

2.3.1 Mapper代理开发概述

之前我们写的代码是基本使用方式,它也存在硬编码的问题,不便于后期的维护。如果使用 Mapper 代理方式则不存在硬编码问题。

 Mapper 代理方式的目的:

  • 解决原生方式中的硬编码

  • 简化后期执行SQL

2.3.2 使用Mapper代理要求

使用Mapper代理方式,必须满足以下要求:

  • 定义与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下。如下图:

  • 设置SQL映射文件的namespace属性为Mapper接口全限定名

  • 在 Mapper 接口中定义方法,方法名就是SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致

2.3.4 案例代码实现

1. 在 com.itheima.mapper 包下创建 UserMapper接口,代码如下:

public interface UserMapper {
     List<User> selectAll();
     User selectById(int id);
 }

2. 在 resources 下创建 com/itheima/mapper 目录,并在该目录下创建 UserMapper.xml 映射配置文件

 <!--
     namespace:名称空间。必须是对应接口的全限定名
 -->
 <mapper namespace="com.itheima.mapper.UserMapper">
     <select id="selectAll" resultType="com.itheima.pojo.User">
         select *
         from tb_user;
     </select>
 </mapper>

3. 在 com.itheima 包下创建 MybatisDemo2 测试类,代码如下:

/**
  * Mybatis 代理开发
  */
 public class MyBatisDemo2 {
 ​
     public static void main(String[] args) throws IOException {
 ​
         //1. 加载mybatis的核心配置文件,获取 SqlSessionFactory
         String resource = "mybatis-config.xml";
         InputStream inputStream = Resources.getResourceAsStream(resource);
         SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
 ​
         //2. 获取SqlSession对象,用它来执行sql
         SqlSession sqlSession = sqlSessionFactory.openSession();
         //3. 执行sql
         //3.1 获取UserMapper接口的代理对象
         UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
         List<User> users = userMapper.selectAll();
 ​
         System.out.println(users);
         //4. 释放资源
         sqlSession.close();
     }
 }

注意:

如果Mapper接口名称和SQL映射文件名称相同,并在同一目录下,则可以使用包扫描的方式简化SQL映射文件的加载。也就是将核心配置文件的加载映射配置文件的配置修改为

 <mappers>
     <!--加载sql映射文件-->
     <!-- <mapper resource="com/itheima/mapper/UserMapper.xml"/>-->
     <!--Mapper代理方式-->
     <package name="com.itheima.mapper"/>
 </mappers>

2.4 核心配置文件

核心配置文件中现有的配置之前已经给大家进行了解释,而核心配置文件中还可以配置很多内容。我们可以通过查询官网看可以配置的内容

2.4.1 配置文件的结构

2.4.2 多环境配置

在核心配置文件的 environments 标签中其实是可以配置多个 environment ,使用 id 给每段环境起名,在 environments 中使用 default='环境id' 来指定使用哪段配置。我们一般就配置一个 environment 即可。

 <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:///mybatis?useSSL=false"/>
             <property name="username" value="root"/>
             <property name="password" value="1234"/>
         </dataSource>
     </environment>
 ​
     <environment id="test">
         <transactionManager type="JDBC"/>
         <dataSource type="POOLED">
             <!--数据库连接信息-->
             <property name="driver" value="com.mysql.jdbc.Driver"/>
             <property name="url" value="jdbc:mysql:///mybatis?useSSL=false"/>
             <property name="username" value="root"/>
             <property name="password" value="1234"/>
         </dataSource>
     </environment>
 </environments>

2.4.3 类型别名

在映射配置文件中的 resultType 属性需要配置数据封装的类型(类的全限定名)。而每次这样写是特别麻烦的,Mybatis 提供了 类型别名(typeAliases) 可以简化这部分的书写。

首先需要现在核心配置文件中配置类型别名,也就意味着给pojo包下所有的类起了别名(别名就是类名),不区分大小写。内容如下:

<typeAliases>
     <!--name属性的值是实体类所在包-->
     <package name="com.itheima.pojo"/> 
 </typeAliases>

通过上述的配置,我们就可以简化映射配置文件中 resultType 属性值的编写

resultType后面的值 可以大写也可以小写 , 在这里指的是User实体类

 <mapper namespace="com.itheima.mapper.UserMapper">
     <select id="selectAll" resultType="user">
         select * from tb_user;
     </select>
 </mapper>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值