Error getting generated key or setting result to parameter object.Cause:javasqlSQLException:无效的列类型..

本文探讨了使用MyBatis框架在Oracle数据库中遇到的主键自增问题,详细分析了错误信息并提供了正确的XML配置解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Error getting generated key or setting result to parameter object.Cause:javasqlSQLException:无效的列类型:getInt not implemented for class oracle.jsbc.driver.T4CRowidAccessor

嗯。。数据库是oracle  持久层框架是 mybatis 配置呢。是xml配置 出问题的配置如下:

<insert id="insertUser"  parameterType="com.tj.mybatis.pojo.user"  useGeneratedKeys="true" keyProperty="id">
	insert into kuser(
			id,
			username,
			birthday,
			sex,
			address
			)
		values (
			KUSER_ID.nextval,
			#{username},
			#{birthday},
			#{sex},
			#{address}
		)
	</insert>

嗯。。然后 问题在于 userGeneratedKeys=“true”  此段配置信息最开始是配置mysql数据库的 ,在mysql中 支持主键自增

而Oracle无法在单表内设置主键自增

 

 useGeneratedKeys="false"

### MyBatis Plus 错误获取生成的键或设置结果到参数对象解决方案 当使用 MyBatis Plus 进行数据库操作时,可能会遇到 `Error getting generated key or setting result to parameter object` 的错误。这通常发生在执行插入语句并尝试获取自动生成的主键值时。 #### 原因分析 此问题可能由多种原因引起: - 数据库配置不正确[^1] - SQL 映射文件中的配置有误[^2] - 使用了不适合的 JDBC 驱动版本[^3] #### 解决方案 ##### 1. 检查数据库表设计 确保数据库表具有自动增长的主键字段,并且该字段被正确定义为 AUTO_INCREMENT 或者序列(取决于使用的数据库类型)。对于 MySQL 数据库而言,应确认 ID 字段已设置为 `AUTO_INCREMENT` 属性[^4]。 ##### 2. 更新 Mapper XML 文件 如果正在手动编写 SQL,则需验证 `<insert>` 标签内的属性是否适当设置了用于返回生成键的相关选项。例如,在 MyBatis 中可以这样定义 insert 语句来处理这种情况: ```xml <insert id="saveUser" useGeneratedKeys="true" keyProperty="id"> INSERT INTO users (name, email) VALUES (#{name}, #{email}) </insert> ``` 这段代码指定了 `useGeneratedKeys=true` 和 `keyProperty=id` 来告知框架应该从数据库中检索新创建记录的主键值并将它赋给实体类对应的成员变量[^5]。 ##### 3. 调整 MyBatis Plus 设置 对于 MyBatis Plus 用户来说,默认情况下会启用全局配置项 `global-config.db-config.id-type=AUTO` ,这意味着插件将会自动识别并支持大多数主流关系型数据库引擎上的自动编号特性。然而,有时仍有必要显式指定这些行为以适应特定需求。可以在 application.yml 或 properties 文件里调整如下所示: ```yaml mybatis-plus: global-config: db-config: id-type: auto # 自增模式 ``` 另外,还可以通过继承 BaseMapper 接口来自定义自己的 mapper 类,并重写 save 方法实现更复杂的逻辑控制[^6]。 ##### 4. 升级依赖包 最后但同样重要的是,请务必保持所用的所有第三方库处于最新稳定版状态。过期版本可能存在 bug 导致上述异常的发生;因此建议定期查看官方文档以及 GitHub 上是否有新的发布版本可用,并及时更新项目里的相关 jar 包[^7]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值