在线教育day1

1. 项目背景


2. 商业模式

2.1 B2C(商家-用户模式)

该模式涉及到2个角色:

  • 管理员 :增删改
  • 用户 :查询

本项目核心模块是课程模块

2.2 B2B2C(商家-商家-商家)

既提供买房与卖方的联系平台,又提供优质的附加服务。
比如:电商平台

2.3 C2C:平台对平台模式

3. 功能模块

3.1后台模块:

在这里插入图片描述

3.2 前台模块

在这里插入图片描述

4. 项目中使用到的技术

项目采用前后端分离开发策略。涉及到的后端技术:Spring Boot,Spring Cloud,MyBatis-Plus,Spring Security,Redis,Maven,JWT,OAuth2。涉及到的前端技术:Vue,Element UI,Axios,Node.js。其他技术:阿里云OSS,阿里视频点播服务,阿里云短信服务,微信支付和登录,Docker,Jenkins,Git。

5. MyBatis-Plus

MyBatis-Plus,Mybatis的增强版本,参考文档


6. 创建工程

1. 创建数据库

  • 创建数据库
CREATE DATABASE mybatis_plus;
  • 创建user表
CREATE TABLE user
(
	id BIGINT(20) NOT NULL COMMENT '主键ID',
	name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
	age INT(11) NULL DEFAULT NULL COMMENT '年龄',
	email VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',
	PRIMARY KEY (id)
);
  • 向User表中插入数据
INSERT INTO user (id, name, age, email) VALUES
(1, 'Jone', 18, 'test1@baomidou.com'),
(2, 'Jack', 20, 'test2@baomidou.com'),
(3, 'Tom', 28, 'test3@baomidou.com'),
(4, 'Sandy', 21, 'test4@baomidou.com'),
(5, 'Billie', 24, 'test5@baomidou.com');

2. IDEA中创建SpringBoot工程

使用 Spring Initializr 快速初始化一个 Spring Boot 工程
Group:com.atguigu
Artifact:mybatis-plus
版本:2.2.1.RELEASE

3. 向项目中导入Maven依赖

<dependencies>
        <!-- SpringBoot启动器 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        
        <!-- SpringBoot test模块 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <!-- 引入Mybatis-plus依赖 -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.3.2</version>
        </dependency>

        <!-- 引入MySQL依赖 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

        <!-- 引入lombok依赖,简化实体类的开发-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
    </dependencies>

4. 配置文件

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=123456

1. 这里的 url 使用了 ?serverTimezone=GMT%2B8 后缀,因为Spring Boot 2.1 集成了 8.0版本的jdbc驱动,这个版本的 jdbc 驱动需要添加这个后缀。
2. 这里的 driver-class-name 使用了 com.mysql.cj.jdbc.Driver ,在 jdbc 8 中 建议使用这个驱动,之前的 com.mysql.jdbc.Driver 已经被废弃,否则运行测试用例的时候会有 WARN 信息。
3.这里还要注意&useUnicode=true&characterEncoding=UTF-8,不然汉字添加进入成了一连串的???

如果配置如下:

#mysql数据库连接
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus
spring.datasource.username=root
spring.datasource.password=123456

可看到出错:

在这里插入图片描述在这里插入图片描述
5. 创建实体类

@Data
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

6. 创建Mapper

创建Mapper包,创建UserMapper,继承BaseMapper,就可以不用配置xml文件。

public interface UserMapper extends BaseMapper<User> {
    
}

7. 主类

@MapperScan用来扫描mapper包下的mapper文件。在这里插入图片描述
8. 配置日志

#mybatis日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

9. 测试

在项目的test文件夹下的测试类中进行数据库连接测试。
在这里插入图片描述
结果如下:
在这里插入图片描述


7. 主键生成策略

在这里插入图片描述
Mybatis-Plus插入代码如下:
在这里插入图片描述
在创建表时,主键ID未设置成自动增长,插入时也未设置id,这里可以看到Mybatis-Plus自动生成了一个19位的ID。

1. 主键ID生成策略:

1.自动增长 AUTO_INCREMENT

缺点:分表的时候不方便:前一个表的最后一个ID+1才是后一个表的第1个ID;

2.UUID:每次生成一个随机唯一的值

缺点:无序,排序不方便;

3.Redis生成ID

缺点:若系统中没Redis,还需要引入新组建,增加系统复杂度

4.Mybatis-Plus自动生成

在这里插入图片描述

2. 自动填充

当表中有创建时间和修改时间等datetime字段时,我们修改或者添加数据时都会先自己手动setCreateTime(new Date()),这里的自动填充意思是Mybatis-Plus可以实现自动为我们填充时间数据。

3. 具体实现:

  1. 在实体类中为要自动填充的属性添加注解
    在这里插入图片描述
  2. 创建类,实现接口MetaObjectHandler,实现接口里面的方法。

在这里插入图片描述
然后进行测试:创建一个用户,未设置创建时间和修改时间
在这里插入图片描述
结果如下,看到自动设置了创建时间和修改时间
在这里插入图片描述
修改用户张三信息,然后查看修改时间:
在这里插入图片描述
可以看到:创建时间未变,修改时间改变了。

4. 乐观锁

解决丢失更新问题。比如:2个事务都对同一变量a=2进行更改时,2个事务都读到a的值是2,一个事务在2的基础上修改了a的值,然后另外一个事务将a的值再进行修改,此时前一个事务的修改丢失了。相当于在a的初始值2的基础上修改,而不是在第一个事务修改后的基础上进行修改。

悲观锁:事务操作时其他事务不能进行操作,即串行操作,效率低。
乐观锁:数据库中添加version字段。在修改时,如果当前版本号等于数据库版本号,则进行修改,版本号+1。否则(即当前版本号小于数据库中的版本号,有其他事务将版本号已经修改了)不能修改。

在这里插入图片描述
乐观锁具体实现

  1. 数据库表添加version字段
    在这里插入图片描述
  2. 实体类添加对应的版本号属性
    在这里插入图片描述
  3. 实体类版本号version添加注解@Version
  4. 配置乐观锁插件

主要创建了一个配置类。
在这里插入图片描述

注意设置version时,给它也设置@TableField(fill = FieldFill.INSERT),让它有个默认值。测试代码如下:
在这里插入图片描述
结果如下,版本号由1变为2。
在这里插入图片描述

在这里插入图片描述
分页查询

  1. 配置一个分页插件
    在这里插入图片描述
  2. 编写分页代码
    new Page(nowPage,pageSize),
    调用Mybatis-Plus的方法实现分页
    在这里插入图片描述
    结果如下:
    在这里插入图片描述

删除

普通查询和批量删除
在这里插入图片描述
逻辑删除

逻辑删除,设置唯一标志位,删除数据时,修改标志位

步骤:

  1. 表中添加删除标志位deleted,实体类中添加deleted属性
    在这里插入图片描述
  2. 配置逻辑删除插件

在这里插入图片描述
测试删除:
在这里插入图片描述
结果如下:deleted为1,表示删除。
在这里插入图片描述
再进行查找测试,结果如下:
在这里插入图片描述
看到Mybatis-Plus只查找deleted为0的记录。

性能分析

配置文件中设置相应地配置
在这里插入图片描述
超时后报错:
在这里插入图片描述

8. wapper

创建Wapper,然后调用方法实现各种条件查询。

在这里插入图片描述在这里插入图片描述


(完)

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值