mybatis-plus: global-config: db-config: logic-delete-field: deleted logic-not-delete-value: 0 logic-delete-value: 1

时间: 2024-03-15 21:43:12 浏览: 23
这段代码是 MyBatis-Plus 的配置,其中 global-config 是全局配置,db-config 是数据库配置。logic-delete-field 表示逻辑删除字段的名称,这里是 deleted;logic-not-delete-value 表示逻辑删除时未删除的值,这里是 0;logic-delete-value 表示逻辑删除时删除的值,这里是 1。这些配置用于实现 MyBatis-Plus 的逻辑删除功能,即在数据库中并不真正删除数据,而是标记为已删除,方便以后查询和恢复。
相关问题

application.yml怎么配置mybatis-plus 修改时id不能为空

在使用MyBatis-Plus进行修改操作时,如果实体类的主键id为空,则MyBatis-Plus会更新整张表的数据,这是一种非常危险的操作。因此,我们需要在application.yml中进行相关配置以避免这种情况的发生。 具体来说,我们需要在application.yml中添加如下配置项: ```yaml mybatis-plus: global-config: db-config: logic-delete-field: deleted logic-delete-value: 1 logic-not-delete-value: 0 ``` 这个配置项会告诉MyBatis-Plus使用逻辑删除的方式来更新数据,即将数据标记为已删除而不是真正的删除。同时,这个配置项还可以指定逻辑删除所使用的字段名和标记已删除和未删除的值。 当我们在进行修改操作时,只需要将实体类的id属性设置为非空即可避免id为空的情况。同时,在进行查询操作时,我们也可以使用MyBatis-Plus提供的逻辑删除功能来查询已删除的数据。 需要注意的是,这个配置项只对使用了MyBatis-Plus的实体类有效,如果您使用的是普通的实体类,则需要在实体类中手动设置逻辑删除的相关属性。

mybatis plus 自动生成代码

MyBatis-Plus 是 MyBatis 的增强工具,提供了多种实用的功能,其中包括自动生成 MyBatis 代码的功能。 MyBatis-Plus 自动生成代码的主要步骤如下: 1. 添加 MyBatis-Plus 依赖 在 Maven 项目中,可以通过添加以下依赖来引入 MyBatis-Plus: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus</artifactId> <version>3.4.2</version> </dependency> ``` 2. 配置代码生成器 MyBatis-Plus 提供了一个代码生成器,可以根据数据库表结构自动生成对应的实体类、Mapper 接口和 XML 映射文件。可以通过创建一个配置类来配置代码生成器。例如: ```java @Configuration public class MybatisPlusConfig { @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return interceptor; } @Bean public ConfigurationCustomizer configurationCustomizer() { return configuration -> configuration.setUseDeprecatedExecutor(false); } @Bean public GlobalConfig globalConfig() { GlobalConfig globalConfig = new GlobalConfig(); globalConfig.setSqlInjector(new LogicSqlInjector()); globalConfig.setMetaObjectHandler(new MyMetaObjectHandler()); globalConfig.setBanner(false); return globalConfig; } @Bean public DataSource dataSource() { // 配置数据源 } @Bean public MybatisSqlSessionFactoryBean mybatisSqlSessionFactoryBean() { MybatisSqlSessionFactoryBean factoryBean = new MybatisSqlSessionFactoryBean(); factoryBean.setDataSource(dataSource()); factoryBean.setPlugins(mybatisPlusInterceptor()); factoryBean.setGlobalConfig(globalConfig()); return factoryBean; } @Bean public MybatisMapperScannerConfigurer mybatisMapperScannerConfigurer() { MybatisMapperScannerConfigurer scannerConfigurer = new MybatisMapperScannerConfigurer(); scannerConfigurer.setBasePackage("com.example.mapper"); return scannerConfigurer; } @Bean public MybatisPlusProperties mybatisPlusProperties() { MybatisPlusProperties properties = new MybatisPlusProperties(); properties.setTypeAliasesPackage("com.example.entity"); return properties; } @Bean public MybatisSqlSessionTemplate mybatisSqlSessionTemplate() throws Exception { return new MybatisSqlSessionTemplate(mybatisSqlSessionFactoryBean().getObject()); } @Bean public MybatisPlusAutoConfiguration mybatisPlusAutoConfiguration(ObjectProvider<List<MybatisPlusPropertiesCustomizer>> mybatisPlusPropertiesCustomizersProvider, ObjectProvider<Interceptor[]> interceptorsProvider, ObjectProvider<LanguageDriver[]> languageDriversProvider, ResourceLoader resourceLoader, ObjectProvider<DatabaseIdProvider> databaseIdProvider, ObjectProvider<List<ConfigurationCustomizer>> configurationCustomizersProvider) { return new MybatisPlusAutoConfiguration(mybatisPlusProperties(), mybatisSqlSessionFactoryBean(), mybatisSqlSessionTemplate(), mybatisMapperScannerConfigurer(), mybatisPlusPropertiesCustomizersProvider.getIfAvailable(), interceptorsProvider.getIfAvailable(), languageDriversProvider.getIfAvailable(), resourceLoader, databaseIdProvider.getIfAvailable(), configurationCustomizersProvider.getIfAvailable()); } } ``` 上述代码中配置了 Mybatis-Plus 的多个组件,包括:数据源、MyBatis 插件、全局配置、Mapper 接口扫描器、实体类别名、SqlSessionFactory 等。 3. 配置代码生成器属性 可以通过在配置文件中添加以下属性来配置代码生成器: ```yaml mybatis-plus: generator: entity: # 实体类配置 output-dir: src/main/java # 输出目录 mapper: # Mapper 接口配置 base-package: com.example.mapper # 包名 xml: src/main/resources/mapper # XML 文件目录 service: # Service 接口配置 base-package: com.example.service # 包名 service-impl: # Service 实现类配置 base-package: com.example.service.impl # 包名 controller: # Controller 类配置 base-package: com.example.controller # 包名 global-config: # 全局配置 db-column-underline: true # 数据库列名是否使用下划线命名 id-type: INPUT # 主键 ID 生成策略 logic-delete-field: deleted # 逻辑删除字段名 logic-delete-value: 1 # 逻辑删除值 logic-not-delete-value: 0 # 逻辑未删除值 ``` 4. 运行代码生成器 在配置好代码生成器后,可以通过运行 MybatisPlusGenerator 类来生成代码。例如: ```java public class MybatisPlusGenerator { public static void main(String[] args) { // 代码生成器 AutoGenerator generator = new AutoGenerator(); // 配置数据源 generator.setDataSource(new DataSourceConfig() .setUrl("jdbc:mysql://localhost:3306/db_test") .setDriverName("com.mysql.jdbc.Driver") .setUsername("root") .setPassword("password")); // 全局配置 generator.setGlobalConfig(new GlobalConfig() .setOutputDir(System.getProperty("user.dir") + "/src/main/java") .setFileOverride(true) .setActiveRecord(true) .setEnableCache(false) .setBaseResultMap(true) .setBaseColumnList(true) .setAuthor("author")); // 包配置 generator.setPackageInfo(new PackageConfig() .setParent("com.example") .setController("controller") .setEntity("entity") .setMapper("mapper") .setService("service") .setServiceImpl("service.impl")); // 策略配置 generator.setStrategy(new StrategyConfig() .setNaming(NamingStrategy.underline_to_camel) .setColumnNaming(NamingStrategy.underline_to_camel) .setEntityLombokModel(true) .setRestControllerStyle(true) .setLogicDeleteFieldName("deleted") .setControllerMappingHyphenStyle(true) .setInclude("table_1", "table_2")); // 执行生成代码 generator.execute(); } } ``` 在运行 MybatisPlusGenerator 类后,将会根据配置生成对应的实体类、Mapper 接口和 XML 映射文件。

相关推荐

最新推荐

recommend-type

mybatis-plus配置控制台打印完整带参数SQL语句的实现

主要介绍了mybatis-plus配置控制台打印完整带参数SQL语句,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

Mybatis-plus基于redis实现二级缓存过程解析

主要介绍了Mybatis-plus基于redis实现二级缓存过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

MyBatis-Plus多表联合查询并且分页(3表联合)

主要介绍了MyBatis-Plus多表联合查询并且分页(3表联合),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

使用mybatis-plus报错Invalid bound statement (not found)错误

主要介绍了使用mybatis-plus报错Invalid bound statement (not found)错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

springboot整合mybatis-plus逆向工程的实现

主要介绍了springboot整合mybatis-plus逆向工程的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

机器学习怎么将excel转为csv文件

机器学习是一种利用计算机算法和统计数据的方法来训练计算机来进行自动学习的科学,无法直接将excel文件转为csv文件。但是可以使用Python编程语言来读取Excel文件内容并将其保存为CSV文件。您可以使用Pandas库来读取Excel文件,并使用to_csv()函数将其保存为CSV格式。以下是代码示例: ```python import pandas as pd # 读取 Excel 文件 excel_data = pd.read_excel('example.xlsx') # 将数据保存为 CSV 文件 excel_data.to_csv('example.csv', index=
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。