1.1跳过测试类打包
需求说明:maven执行打包命令时,默认条件下会执行测试类中的方法,测试方法中一旦报错,则install的操作执行失败。
解决方案: 要求install时 不要执行test方法。
解决方案:跳过测试类打包
<properties>
<!--指定JDK版本-->
<java.version>1.8</java.version>
<!--跳过测试类打包-->
<skipTests>true</skipTests>
</properties>
1.2创建项目。
对demo_user数据进行增删改查
1创建maven工程
2.导入pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.jt</groupId>
<artifactId>demo</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.3</version>
<relativePath/>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<!--Springboot的启动器 在内部已经将整合的配置写好,实现拿来就用-->
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--支持热部署 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
<!--引入插件lombok 自动的set/get/构造方法插件 -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.0</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.48</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
<version>2.5.3</version>
</dependency>
</dependencies>
</project>
编辑主启动类
Spring管理Mapper接口(方式一)
说明: @Mapper注解 一般标识接口中. 如果有多个接口,则应该标识多次.
优化: 可以采用 @MapperScan(“xxxx”)进行优化.
Spring管理Mapper接口(方式二)
package com.jt; import org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication @MapperScan("com.jt.dao") public class Runapp { public static void main(String[] args) { SpringApplication.run(Runapp.class, args); } }
数据库
1.4 整合mybatis
//序列化接口的作用:保证对象网络传输的有效性
package com.jt.pojo; import lombok.Data; import lombok.experimental.Accessors; import java.io.Serializable; @Data @Accessors(chain = true) public class User implements Serializable { private Integer id; private String name; private Integer age; private String sex; }
1.4.2 编辑YML文件
编辑 1.数据源 2.整合mybatis
#端口配置 server: port: 8080 #配置数据源 spring: datasource: #如果使用高版本驱动 则添加cj driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/jt?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true username: root password: root #Spring整合Mybatis mybatis: #定义别名包 type-aliases-package: com.jt.pojo #导入映射文件 mapper-locations: classpath:/mappers/*.xml #开启驼峰映射 configuration: map-underscore-to-camel-case: true
- 数据库配置参数:
- 1.serverTimezone=GMT%2B8& 时区
- 2.useUnicode=true& 是否使用unicode编码
- 3.characterEncoding=utf8& 字符集使用utf-8
- 4.autoReconnect=true& 自动重连
- 5.allowMultiQueries=true 运行批量操作
1.4.3 编辑映射文件
<?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.jt.dao.UserMapper"> <!--查询全表--> <select id="getlist" resultType="User"> select * from demo_user </select> <!--按照id删除--> <delete id="delete"> delete from demo_user where id=#{id} </delete> <!--增加记录--> <insert id="insert"> insert into demo_user values (#{id},#{name},#{age},#{sex}) </insert> <!--修改--> <update id="update"> update demo_user set name=#{newname} where id=#{id} </update> </mapper>
编辑测试类
package com.jt.test; import com.jt.dao.UserMapper; import com.jt.pojo.User; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import java.util.List; @SpringBootTest public class Test { @Autowired private UserMapper userMapper; @org.junit.jupiter.api.Test public void test(){ List<User> getlist = userMapper.getlist(); System.out.println(getlist); //删除 userMapper.delete(233); //增加 User user = new User().setId(null).setName("HANY").setAge(156).setSex("女"); userMapper.insert(user); //更新 userMapper.update(234, "eafhf"); } }
Bug
说明: 通过包扫描的路径,在运行期间实现对象的创建. 实现了数据的绑定.所以下边的红线属于误报…
解决方案
说明: 如果xml的映射文件,则根目录下(不建议), 则加载时采用classpath*😕*.xml的结构.
强制加载根目录下的所有的xml文件.
放在文件夹下
2. MybatisPlus学习
ORM思想,对象关系映射(object Relational Mapping),是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换
面向对象的方式来操作数据库!
以对象的方式实现数据库CRUD操作
要求通过某种机制将对象动态的转换为sql,之后实现数据库的操作,可以不写sql语句
2.2 Mybatis优点/缺点
优点:
1.Mybatis 内部整合了JDBC, 简化了持久层开发.
2.Mybatis可以自动的封装结果集的对象 满足ORM中的一个条件.所以将Mybatis称之为半自动化的ORM映射框架.
3.Mybatis有缓存机制 一级缓存/二级缓存.提高用户得查询效率.
4.Mybatis支持多种类型的数据库. 整合简单.
缺点:
1.实现数据的封装 resultMap 封装复杂!!!
2.针对于单表的CRUD的操作 不够便捷. Sql都需要手写!!!
3.个别的情况下二级缓存配置不生效!!!
2.4 MP入门案例(数据库表同上)
第一,导入jar包更换原有mybatis
<dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.3</version> </dependency>
2.4.2 实现映射
关键在于继承特定的接口
关键词: 封装—多态—继承
说明: MP在内部准备一个BaseMapper的接口 BaseMapper内部几乎将单表的CURD操作 都进行了编辑. 用户自己的Mapper接口可以继承即可.
package com.jt.mapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.jt.pojo.User; import java.util.List; //@Mapper将该接口交给Spring管理 public interface UserMapper extends BaseMapper<User> { List<User> get(); }
第三步 yml文件中mybatis改成
mybatis-plus:
最后可以进行测试:!!!
package com.jt.test; import com.jt.mapper.UserMapper; import com.jt.pojo.User; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; @SpringBootTest public class TestMP { @Autowired private UserMapper userMapper; @Test public void test01(){ //增加 User user = new User(); user.setName("阿富汗").setAge(40).setSex("厉害"); userMapper.insert(user); //查询 User user1 = userMapper.selectById(21); System.out.println(user1); } }
分析问题: 对象如何转化为Sql.
核心理论
.例子: userMapper.insert(user);
dogMapper.insert(dog);
关键在转化
Sql:
1. insert into 表名(字段名称…) value (属性的值…)
总结: MP将常规的操作进行抽取, 采用公共的接口进行定义. 之后只需要按照用户的参数, 动态的拼接Sql即可.
重点: 对java反射机制 有一定的了解
-
userMapper.insert(user); 用户传入user对象,通过对象.getclass()获取类型
-
根据class的类型,通过反射动态获取指定的注解@TableName("demo_user"),得到表tableName.value();
- 根据class的类型,知道其属性,由属性名称获取注解,获取到表字段的名称@TableField(“name”),
- 最终拼接出完整的sql语句
- 最终将Sql 由MP交给Mybatis执行sql. 最终实现数据的入库操作.