Mybatis逆向工程Mapper.xml中字段与数据库中字段名字不一致

### Cause: java.sql.SQLSyntaxErrorException: Unknown column 'create_time' in 'field list'
; bad SQL grammar []; nested exception is java.sql.SQLSyntaxErrorException: Unknown column 'create_time' in 'field list'] with root cause
java.sql.SQLSyntaxErrorException: Unknown column 'create_time' in 'field list'

数据库中t_emp表中字段名称为并没有create_time,并且在映射文件EmpMapper.xml有一些字段名称都没有生成.
我的数据库版本用的是
在这里插入图片描述
原因:
逆向工程生成代码的过程中,不光会根据我们指定数据库mybatis中的表生成了代码,而且还根据系统自带的同名数据库表又生成了代码,两张表名称相同,生成的代码都合并到了一起,导致了错误(推测:或者你其他自定义数据库中有同名的表,可能也会出错,因为我出现过这种问题)

解放方法一:修改逆向工程的jdbc配置(推荐)
在generatorConfig.xml的数据库连接信息处添加一条标签

<!--解决mysql驱动升级到8.0后不生成指定数据库代码的问题-->
 <property name="nullCatalogMeansCurrent" value="true" />
<!-- 数据库的连接信息 -->
        <jdbcConnection
                driverClass="com.mysql.cj.jdbc.Driver"
                connectionURL="jdbc:mysql://localhost:3306/mybatis?useUnicode=true&amp;characterEncoding=utf8&amp;serverTimezone=GMT&amp;useSSL=FALSE"
                userId="root"
                password="root">
            <!--解决mysql驱动升级到8.0后不生成指定数据库代码的问题-->
            <property name="nullCatalogMeansCurrent" value="true" />
        </jdbcConnection>

解决方法二:修改我们要逆向工程自动生成的表的名字
修改我们要逆向工程自动生成的表的名字,使之不要与同一个数据库下的其他表的名字有所重复

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值