关于Mybatis-generator中,<properties> resource jdbc.properties does not exist 的问题

问题:

  generatorConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
 
<generatorConfiguration>
    <!--导入属性配置-->
    <properties resource="jdbc.properties"></properties>
 
    <!-- 指定数据库驱动的jdbc驱动jar包的位置 -->
    <classPathEntry location="mysql-connector-java-5.1.47.jar" />
 
    <!-- context 是逆向工程的主要配置信息 -->
    <!-- id:名字 -->
    <!-- targetRuntime:设置生成的文件适用于 mybatis 版本 -->
    <context id="default" targetRuntime="MyBatis3">
 
        <!--optional,旨在创建class时,对注释进行控制-->
        <commentGenerator>
            <property name="suppressDate" value="true" />
            <!-- 是否去除自动生成的注释 true:是 : false:否 -->
            <property name="suppressAllComments" value="true" />
        </commentGenerator>
 
        <!--jdbc的数据库连接-->
        <jdbcConnection driverClass="${spring.datasource.driver-class-name}"
                        connectionURL="${spring.datasource.url}"
                        userId="${spring.datasource.username}"
                        password="${spring.datasource.password}">
        </jdbcConnection>
 
        <!--非必须,类型处理器,在数据库类型和java类型之间的转换控制-->
        <javaTypeResolver>
            <!-- 默认情况下数据库中的 decimal,bigInt 在 Java 对应是 sql 下的 BigDecimal 类 -->
            <!-- 不是 double 和 long 类型 -->
            <!-- 使用常用的基本类型代替 sql 包下的引用类型 -->
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>
 
        <!-- targetPackage:生成的实体类所在的包 -->
        <!-- targetProject:生成的实体类所在的硬盘位置 -->
        <javaModelGenerator targetPackage="com.is.pojo"
                            targetProject=".\src\main\java">
            <!-- 是否允许子包 -->
            <property name="enableSubPackages" value="false" />
            <!-- 是否对modal添加构造函数 -->
            <property name="constructorBased" value="true" />
            <!-- 是否清理从数据库中查询出的字符串左右两边的空白字符 -->
            <property name="trimStrings" value="true" />
            <!-- 建立modal对象是否不可改变 即生成的modal对象不会有setter方法,只有构造方法 -->
            <property name="immutable" value="false" />
        </javaModelGenerator>
 
        <!-- targetPackage 和 targetProject:生成的 mapper 文件的包和位置 -->
        <sqlMapGenerator targetPackage="mappers"
                         targetProject=".\src\main\resource\mybatis\common">
            <!-- 针对数据库的一个配置,是否把 schema 作为字包名 -->
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>
 
        <!-- targetPackage 和 targetProject:生成的 interface 文件的包和位置 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="com.is.dao" targetProject=".\src\main\java">
            <!-- 针对 oracle 数据库的一个配置,是否把 schema 作为字包名 -->
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>
        <table tableName="user" domainObjectName="User"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
    </context>
</generatorConfiguration>

  jdbc.properties

spring.datasource.driverLocation=mysql-connector-java-5.1.47.jar
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/is_db?characterEncoding=utf-8
spring.datasource.username=root
spring.datasource.password=123456

在使用Mybatis-generator中,配置文件时,出现问题

MyBatis Generator Started...
  Buildfile: E:\Workspace\sts-workspace\.metadata\.plugins\org.mybatis.generator.eclipse.ui\.generatedAntScripts\LeafageUnifiedDevelopmentPlatform-generatorConfig.xml.xml
  11:14:53.494 [Worker-18: Launching LeafageUnifiedDevelopmentPlatform-generatorConfig.xml] DEBUG org.mybatis.generator.eclipse.ui.ant.logging.AntLogFactory - Logging initialized using 'org.mybatis.generator.eclipse.ui.ant.logging.slf4j.Slf4jLoggingLogFactory@49a26000' adapter.
  11:14:53.509 [Worker-18: Launching LeafageUnifiedDevelopmentPlatform-generatorConfig.xml] DEBUG org.mybatis.generator.logging.LogFactory - Logging initialized using 'org.mybatis.generator.eclipse.ui.ant.logging.AntLogFactory@14794f6e' adapter.
  <properties> resource jdbc.properties does not exist
MyBatis Generator Finished

解决:

  不是像网上查到的加classpath,修改

<!--导入属性配置-->
    <properties resource="jdbc.properties"></properties>

<!--导入属性配置-->
    <properties resource="config/jdbc.properties"></properties>

文件目录展示如下

原因:

properties会去src/main/resourses目录下寻找,而我们经常将目录再添加一层conf或者config,就要修改指向conf或者config目录。

评论回复说明:首先,使用mybatis generator弄清楚,有2个文件一个是 mybatisGenerator.xml,这个是用来运行的;还有个是jdbc.properties文件,这个是jdbc的配置文件(可以写在mybatisGenerator.xml里,但是为了可迁移性,就把独立出来了)。

目前问题主要出现在,mybatisGenerator.xml寻找jdbc.properties文件,找不到。部分原因在于,有的教程是resource文件夹下,直接写jdbc.properties,有的教程会写在resource/config目录下,只要弄清这点就没有问题了。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值