mybatis-plus教程-Mybatis-plus使用Oracle 主键Sequence

完整代码

https://github.com/pbteach/mybatis-plus-test

完整讲义

http://www.pbteach.com/post/java_distribut/mybatis-plus-01/

http://www.pbteach.com/post/java_distribut/mybatis-plus-02/

Mybatis-plus使用Oracle 主键Sequence

在mysql中,主键往往是自增长的,这样使用起来是比较方便的,如果使用的是Oracle数据库,那么就不能使用自增长了,就得使用Sequence 序列生成id值了。

部署Oracle环境

为了简化环境部署,这里使用Docker环境进行部署安装Oracle。

#拉取镜像
docker pull sath89/oracle-12c

#创建容器
docker create --name oracle -p 1521:1521 sath89/oracle-12c

#启动
docker start oracle && docker logs -f oracle

#下面是启动过程
Database not initialized. Initializing database.
Starting tnslsnr
Copying database files
1% complete
3% complete
11% complete
18% complete
26% complete
37% complete
Creating and starting Oracle instance
40% complete
45% complete
50% complete
55% complete
56% complete
60% complete
62% complete
Completing Database Creation
66% complete
70% complete
73% complete
85% complete
96% complete
100% complete
Look at the log file "/u01/app/oracle/cfgtoollogs/dbca/xe/xe.log" for further details.
Configuring Apex console
Database initialized. Please visit http://#containeer:8080/em http://#containeer:8080/apex for extra configuration if needed
Starting web management console

PL/SQL procedure successfully completed.

Starting import from '/docker-entrypoint-initdb.d':
ls: cannot access /docker-entrypoint-initdb.d/*: No such file or directory
Import finished

Database ready to use. Enjoy! ;)

#通过用户名密码即可登录
用户名和密码为: system/oracle

下面使用navicat12进行连接并操作oracle,使用资料中提供的安装包,可以试用14天。

需要注意的是:由于安装的Oracle是64位版本,所以navicat也是需要使用64为版本,否则连接不成功。

1556525517473

连接成功:

1556525564083

创建表以及序列

--创建表,表名以及字段名都要大写
CREATE TABLE "TB_USER" (
  "ID" NUMBER(20) VISIBLE NOT NULL ,
  "USER_NAME" VARCHAR2(255 BYTE) VISIBLE ,
  "PASSWORD" VARCHAR2(255 BYTE) VISIBLE ,
  "NAME" VARCHAR2(255 BYTE) VISIBLE ,
  "AGE" NUMBER(10) VISIBLE ,
  "EMAIL" VARCHAR2(255 BYTE) VISIBLE 
)

--创建序列
CREATE SEQUENCE SEQ_USER START WITH 1 INCREMENT BY 1

jdbc驱动包

由于版权原因,我们不能直接通过maven的中央仓库下载oracle数据库的jdbc驱动包,所以我们需要将驱动包安装到本地仓库。

#ojdbc8.jar文件在资料中可以找到

mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc8 -Dversion=12.1.0.1 -Dpackaging=jar -Dfile=ojdbc8.jar

安装完成后的坐标:

<dependency>
    <groupId>com.oracle</groupId>
    <artifactId>ojdbc8</artifactId>
    <version>12.1.0.1</version>
</dependency>

修改application.properties

对于application.properties的修改,需要修改2个位置,分别是:

#数据库连接配置
spring.datasource.driver-class-name=oracle.jdbc.OracleDriver
spring.datasource.url=jdbc:oracle:thin:@192.168.31.81:1521:xe
spring.datasource.username=system
spring.datasource.password=oracle

#id生成策略
mybatis-plus.global-config.db-config.id-type=input

配置序列

使用Oracle的序列需要做2件事情:

第一,需要配置MP的序列生成器到Spring容器:

package com.pbteach.mp;

import com.baomidou.mybatisplus.extension.incrementer.OracleKeyGenerator;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
@MapperScan("com.pbteach.mp.mapper") //设置mapper接口的扫描包
public class MybatisPlusConfig {

    /**
     * 分页插件
     */
    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }

    /**
     * 序列生成器
     */
    @Bean
    public OracleKeyGenerator oracleKeyGenerator(){
        return new OracleKeyGenerator();
    }
}

第二,在实体对象中指定序列的名称:

@KeySequence(value = "SEQ_USER", clazz = Long.class)
public class User{
    ......
}

测试

package com.pbteach.mp;

import com.pbteach.mp.mapper.UserMapper;
import com.pbteach.mp.pojo.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.List;

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserMapperTest {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testInsert(){
        User user = new User();
        user.setAge(20);
        user.setEmail("test@pbteach.com");
        user.setName("曹操");
        user.setUserName("caocao");
        user.setPassword("123456");

        int result = this.userMapper.insert(user); //返回的result是受影响的行数,并不是自增后的id
        System.out.println("result = " + result);

        System.out.println(user.getId()); //自增后的id会回填到对象中
    }

    @Test
    public void testSelectById(){
        User user = this.userMapper.selectById(8L);
        System.out.println(user);
    }

}

1573690675905

ser.getId()); //自增后的id会回填到对象中
}

@Test
public void testSelectById(){
    User user = this.userMapper.selectById(8L);
    System.out.println(user);
}

}

![在这里插入图片描述](https://imgconvert.csdnimg.cn/aHR0cDovL3d3dy5wYnRlYWNoLmNvbS9wb3N0L2phdmFfZGlzdHJpYnV0L215YmF0aXMtcGx1cy0wMi8xNTczNjkwNjc1OTA1LnBuZw?x-oss-process=image/format,png)


  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: mybatis-plus提供了多种主键生成策略,常用的有以下几种: 1. 默认的主键生成策略:使用数据库自增长方式生成主键。对于MySQL数据库,使用AUTO_INCREMENT关键字,对于Oracle数据库,使用SEQUENCE序列。 2. UUID主键生成策略:使用Java中的UUID类生成主键,生成的主键是32位的16进制字符串,不重复且无序。 3. 雪花算法主键生成策略:雪花算法是Twitter开源的一个分布式ID生成算法,可以保证在分布式环境下生成的ID全局唯一且有序。 在使用mybatis-plus时,可以通过注解@TableId和@TableField来指定主键和字段的属性,包括主键生成策略。例如: ``` @TableId(value = "id", type = IdType.AUTO) private Long id; @TableId(value = "uuid", type = IdType.UUID) private String uuid; @TableId(value = "id", type = IdType.ID_WORKER) private Long idWorker; @TableId(value = "id", type = IdType.SNOWFLAKE) private Long snowflakeId; ``` 其中,@TableId注解的value属性指定了数据库表中对应的字段名,type属性指定了主键生成策略。MyBatis-Plus是一个基于MyBatis的增强工具,提供了许多方便开发的特性和功能,可以大大减少我们在开发中的代码量和复杂度。 以下是使用MyBatis-Plus的主要策略: 1. 使用代码生成器:MyBatis-Plus提供了一个代码生成器,可以自动生成Mapper、Entity和Service层的代码,大大减少了手写代码的工作量。我们只需要配置好生成器的相关信息,就可以快速生成我们需要的代码。 2. 使用MyBatis-Plus的BaseMapper:MyBatis-Plus的BaseMapper提供了很多基础的CRUD操作,如selectById、selectBatchIds、insert、update、delete等,可以大大减少我们手写Mapper的工作量。同时,我们也可以扩展BaseMapper,添加自定义的方法。 3. 使用MyBatis-Plus的Wrapper:MyBatis-Plus的Wrapper提供了一种更加灵活的查询方式,可以通过构建Wrapper对象来构造复杂的查询条件。Wrapper可以用于查询、更新和删除操作。 4. 使用MyBatis-Plus的分页插件:MyBatis-Plus提供了一个分页插件,可以方便地进行分页查询操作。我们只需要在Mapper接口中定义对应的方法,然后在Service层中调用即可。 5. 使用MyBatis-Plus的自动填充功能:MyBatis-Plus的自动填充功能可以自动为我们的实体类填充一些公共字段,如创建时间、更新时间等。我们只需要在实体类中定义对应的字段和注解,就可以自动填充这些字段。 总的来说,MyBatis-Plus是一个非常方便实用的工具,可以大大提高我们的开发效率和代码质量。 ### 回答2: Mybatis-plus是一个基于Mybatis框架的扩展插件,为Mybatis提供了更多的功能和便利。在Mybatis-plus中,主键生成策略是一个非常重要的功能。主键生成策略是指在数据库表中添加一条记录时,如何为这条记录生成一个唯一的主键值,通常情况下我们会采用自增长主键、UUID等方式来生成主键值。而Mybatis-plus则提供了多种主键生成策略,下面我们就一一进行讲解。 1. 自增主键 Mybatis-plus中支持使用数据库自增主键作为主键生成策略,例如MySQL中的AUTO_INCREMENT。在使用自增主键时,只需要在实体类中的主键字段上加上@TableId注解,并设置类型为IdType.AUTO即可。 2. UUID主键 Mybatis-plus中还提供了UUID作为主键生成策略,这种方式的好处就在于适用于分布式系统环境下,可以保证每个分布式节点都能生成唯一的主键。在使用UUID主键时,只需要在实体类中的主键字段上加上@TableId注解,并设置类型为IdType.ASSIGN_UUID即可。 3. 雪花算法主键 Mybatis-plus中还提供了snowflake算法作为主键生成策略,这种方式的好处就在于生成的主键值有序递增、性能高、不存在重复主键的问题。在使用雪花算法主键时,只需要在实体类中的主键字段上加上@TableId注解,并设置类型为IdType.ASSIGN_ID即可。 4. 自定义主键生成器 如果以上提到的主键生成策略都不能满足需求,那么我们可以在Mybatis-plus中自定义主键生成器。自定义主键生成器需要实现IdentifierGenerator接口,并在实体类中的主键字段上加上@TableId注解,并通过type属性指定自定义主键生成器类的全路径名。 在使用Mybatis-plus进行开发时,选取合适的主键生成策略有助于提升项目的性能和可靠性。上述几种主键生成策略都经过了充分测试和实践,在实际开发中可放心使用。 ### 回答3: MyBatis-PlusMyBatis 的一个开源插件,提供了很多强大的功能,其中包括主键生成策略,下面就来详细介绍一下 MyBatis-Plus 主键生成策略。 1. 自增主键 自增主键就是数据库中自带的主键,只需要在实体类中将主键属性添加 @TableId 注解,并设置主键生成策略为 IDENTITY 即可,例如: ``` @TableId(type = IdType.AUTO) private Long id; ``` 2. UUID 主键 UUID 是一种通用唯一识别码,可以用于分布式系统中的唯一标识。在 MyBatis-Plus 中,只需要在实体类中将主键属性添加 @TableId 注解,并设置主键生成策略为 UUID 即可,例如: ``` @TableId(type = IdType.UUID) private String id; ``` 3. 雪花算法主键 雪花算法是一种能够生成唯一 ID 的算法,使用 64 位的整数作为 ID,其中高位是时间信息,中间位是工作机器 ID,低位是序列号。在 MyBatis-Plus 中,只需要在实体类中将主键属性添加 @TableId 注解,并设置主键生成策略为 SNOWFLAKE 即可,例如: ``` @TableId(type = IdType.SNOWFLAKE) private Long id; ``` 4. 自定义主键生成器 如果以上主键生成策略都无法满足需求,还可以自定义主键生成器。只需要实现 IKeyGenerator 接口,然后在实体类中将主键属性添加 @TableId 注解,并设置主键生成策略为自定义的生成器即可,例如: ``` @TableId(type = IdType.ASSIGN_ID, idGenerator = CustomIdGenerator.class) private Long id; ``` 以上就是 MyBatis-Plus 主键生成策略的详细介绍,根据具体的业务需求选择合适的主键生成策略可以提高系统的性能和可维护性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值