mybatisplus命名有哪些策略
时间: 2023-08-14 15:08:44 浏览: 51
MyBatis-Plus(简称为MP)是一个基于MyBatis的增强工具,它提供了许多命名策略来帮助开发者处理数据库表和实体类之间的命名转换。以下是一些常用的命名策略:
1. `underline_to_camel`:下划线转驼峰命名策略,例如 "user_name" 转换为 "userName"。
2. `no_change`:不做任何改变,保持原始命名不变。
3. `insert_upper`:将数据库列名转换为大写,例如 "user_name" 转换为 "USER_NAME"。
4. `insert_lower`:将数据库列名转换为小写,例如 "USER_NAME" 转换为 "user_name"。
5. `upper_camel`:将每个单词首字母大写,其余字母小写,例如 "user_name" 转换为 "UserName"。
6. `lower_camel`:将第一个单词首字母小写,其余字母大小写不变,例如 "USER_NAME" 转换为 "userName"。
在MyBatis-Plus中,你可以通过配置 `GlobalConfig` 来设置全局的命名策略,也可以通过注解 `@TableField` 和 `@TableId` 来指定特定字段的命名策略。
希望以上答案能够对你有所帮助。如果你对其他方面有更多问题,请随时提问!
相关问题
mybatisplus主键策略自动生成
MyBatis-Plus(简称MP)是基于 MyBatis 的增强工具,它提供了许多方便的功能来简化开发过程。在 MyBatis-Plus 中,主键策略的自动生成可以通过使用注解来实现。
首先,你需要在实体类的主键字段上使用 `@TableId` 注解指定主键的生成策略。`@TableId` 注解有几个常用的属性,其中 `type` 属性用于指定主键生成策略的类型。
以下是几种常见的主键生成策略:
1. 使用数据库自增主键:设置 `type = IdType.AUTO`。这种策略适用于主键使用数据库自增的情况,比如 MySQL 中的自增主键。
```java
@TableId(type = IdType.AUTO)
private Long id;
```
2. 使用全局唯一ID:设置 `type = IdType.ASSIGN_ID`。这种策略适用于使用全局唯一ID生成器来生成主键,比如 Snowflake 算法生成的ID。
```java
@TableId(type = IdType.ASSIGN_ID)
private Long id;
```
3. 雪花算法ID:设置 `type = IdType.ID_WORKER`。这种策略适用于使用雪花算法生成分布式唯一ID。
```java
@TableId(type = IdType.ID_WORKER)
private Long id;
```
另外,你还可以使用 `@TableField` 注解来自定义主键的命名和映射关系。
以上是 MyBatis-Plus 中实现主键自动生成的常见方式,根据你的具体需求选择合适的策略进行配置。
mybatisplus驼峰失效
mybatisplus驼峰失效是因为mybatis-plus默认的驼峰命名规则是开启的,但在某些情况下会出现失效的情况。解决这个问题的方法有两种:
1. 使用对象包装工厂:
您可以在配置文件中指定使用MybatisMapWrapperFactory作为对象包装工厂。您可以在配置类中添加以下代码:
```java
@Bean
public ConfigurationCustomizer mybatisConfigurationCustomizer() {
return configuration ->
configuration.setObjectWrapperFactory(new MybatisMapWrapperFactory());
}
```
2. 配置全局驼峰命名策略:
您可以在配置文件中配置全局的驼峰命名策略。在Spring-Mybatis.xml中找到SqlSessionFactory配置,并添加以下属性:
```xml
<property name="globalConfig" ref="globalConfig" />
```
然后,在配置文件中配置GlobalConfig:
```xml
<bean id="globalConfig" class="com.baomidou.mybatisplus.core.config.GlobalConfig">
<property name="dbConfig" ref="dbConfig" />
<property name="sqlInjector" ref="sqlInjector" />
<property name="idType" value="AUTO" />
<property name="fieldStrategy" value="NOT_EMPTY" />
<property name="tablePrefix" value="" />
<property name="tablePrefix" value="" />
<property name="sqlParserCache" value="true" />
<property name="keyGenerator" ref="keyGenerator" />
<property name="metaObjectHandler" ref="metaObjectHandler" />
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>
```
以上是解决mybatisplus驼峰失效的两种方法。您可以根据您的实际情况选择其中一种方法进行配置。