oracle序列nextval报空指针,Derby上的Oracle序列nextval问题

我们在Oracle数据库上方的应用程序中有多个MyBatis查询,它使用序列生成自己的ID值以供进一步使用

select s_seq1.nextval from dual

insert into some_table

(some_id, some_data, created_on, created_by)

values

(#{someId}, #{someData}, #{createdOn}, #{createdBy})

我们现在正尝试使用Derby数据库为应用程序编写集成测试,但由于没有双表,我们尝试通过创建一个名为dual的伪视图来实现上述查询,其中包含序列nextval表达式作为其列。具有两个示例列的Liquibase变更集如下

检查Derby内容,该视图已成功创建,但在运行测试时,我们仍会收到上述查询的异常

java.sql.SQLSyntaxErrorException: Column 'S_SEQ1.NEXTVAL' is either not in any table in the FROM list or appears within a join specification

and is outside the scope of the join specification or appears in a HAVING clause and is not in the GROUP BY list.

问题似乎是由于点我们必须在引号之间创建假视图列,因此MyBatis查询也可以在Derby上使用引号之间的列名,但这样就可以在Oracle上创建真正的应用程序失败。这似乎是一种僵局。任何想法都将不胜感激。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值