### 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&characterEncoding=utf8&serverTimezone=GMT&useSSL=FALSE"
userId="root"
password="root">
<!--解决mysql驱动升级到8.0后不生成指定数据库代码的问题-->
<property name="nullCatalogMeansCurrent" value="true" />
</jdbcConnection>
解决方法二:修改我们要逆向工程自动生成的表的名字
修改我们要逆向工程自动生成的表的名字,使之不要与同一个数据库下的其他表的名字有所重复