mybatis-plus的IdType
时间: 2023-09-24 18:13:52 浏览: 181
Mybatis-Plus是一个优秀的Mybatis增强工具,在实体类中通过注解@TableId来标识主键字段,此注解有一个属性:type,用于设置主键类型,其中IdType是其中一个枚举类型。
IdType枚举类型定义了4种主键类型:
- AUTO:数据库ID自增
- NONE:未设置主键
- INPUT:手动输入ID
- ID_WORKER:默认的全局唯一ID
其中,ID_WORKER是Mybatis-Plus中默认的主键类型,使用雪花算法生成全局唯一ID,具备以下优点:
- 全局唯一
- 高性能
- 无需网络
- 无中心化
如果您需要手动输入ID,可以使用@IdType(type = IdType.INPUT)来设置主键类型,但是需要手动设置ID值。如果您需要使用数据库自增,可以使用@IdType(type = IdType.AUTO)来设置主键类型,但是需要确保数据库表的主键设置为自增。
相关问题
mybatis-plus idtype
mybatis-plus idtype是指Mybatis-Plus配置中的主键类型。默认情况下,Mybatis-Plus使用Long类型作为主键,但是可以根据需要进行修改,支持的主键类型包括:Long, Integer, String, BigInteger, BigDecimal。可以在实体类中使用注解@TableId(type = IdType.xxx)来指定主键类型。
Mybatis-plus技术博客如何使用mybatis-plus进行增删改查
Mybatis-plus 是一个 Mybatis 的增强工具,提供了很多方便的操作方法,可以使我们的开发效率更高、更简洁。下面是使用 Mybatis-plus 进行增删改查的示例:
1. 添加依赖
在 pom.xml 文件中添加以下依赖:
```xml
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.3.1</version>
</dependency>
```
2. 配置数据源
在 application.properties 文件中配置数据源信息:
```properties
spring.datasource.url = jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=Asia/Shanghai
spring.datasource.username = root
spring.datasource.password = 123456
spring.datasource.driver-class-name = com.mysql.cj.jdbc.Driver
```
3. 创建实体类
创建一个实体类,可以使用注解 @TableName 指定数据库表名,@TableId 指定主键字段。
```java
@Data
@TableName("user")
public class User {
@TableId(type = IdType.AUTO)
private Long id;
private String name;
private Integer age;
private String email;
}
```
4. 创建 Mapper 接口
创建一个 Mapper 接口,继承 BaseMapper 类,可以直接使用 Mybatis-plus 提供的方法,无需手写 SQL。
```java
@Mapper
public interface UserMapper extends BaseMapper<User> {
}
```
5. 使用 Mybatis-plus 进行增删改查
使用 Mybatis-plus 提供的方法进行增删改查操作。
```java
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public void addUser(User user) {
userMapper.insert(user);
}
@Override
public void deleteUserById(Long id) {
userMapper.deleteById(id);
}
@Override
public void updateUser(User user) {
userMapper.updateById(user);
}
@Override
public User getUserById(Long id) {
return userMapper.selectById(id);
}
@Override
public List<User> getUserList() {
return userMapper.selectList(null);
}
}
```
以上就是使用 Mybatis-plus 进行增删改查的示例。当然,Mybatis-plus 还提供了其他很多方便的操作方法,可以根据具体需求进行使用。
阅读全文