为了账号安全,请及时绑定邮箱和手机立即绑定

插入时出现 ORA-04043

插入时出现 ORA-04043

开心每一天1111 2023-08-23 17:19:06
我们正在尝试存储一条记录:DSLContext dsl = DSL.using(conn, SQLDialect.ORACLE12C);KampartikelRecord kampartikelRecord = dsl.newRecord(KAMPARTIKEL);kampartikelRecord.setKampagne(387);kampartikelRecord.setArtnr("090248");kampartikelRecord.setArtId(5558);kampartikelRecord.store();但我们得到:org.jooq.exception.DataAccessException: SQL [insert into "TOSCA"."KAMPARTIKEL" ("KAMPAGNE", "ART_ID", "ARTNR") values (?, ?, ?)]; ORA-04043: Objekt "TOSCA" ist nicht vorhanden    at org.jooq_3.12.1.ORACLE12C.debug(Unknown Source)    at org.jooq.impl.Tools.translate(Tools.java:2717)    at org.jooq.impl.DefaultExecuteContext.sqlException(DefaultExecuteContext.java:755)    at org.jooq.impl.AbstractQuery.execute(AbstractQuery.java:383)    at org.jooq.impl.TableRecordImpl.storeInsert0(TableRecordImpl.java:206)    at org.jooq.impl.TableRecordImpl$1.operate(TableRecordImpl.java:177)    at org.jooq.impl.RecordDelegate.operate(RecordDelegate.java:130)    at org.jooq.impl.TableRecordImpl.storeInsert(TableRecordImpl.java:173)    at org.jooq.impl.UpdatableRecordImpl.store0(UpdatableRecordImpl.java:196)    at org.jooq.impl.UpdatableRecordImpl$1.operate(UpdatableRecordImpl.java:136)    at org.jooq.impl.RecordDelegate.operate(RecordDelegate.java:130)    at org.jooq.impl.UpdatableRecordImpl.store(UpdatableRecordImpl.java:132)    at org.jooq.impl.UpdatableRecordImpl.store(UpdatableRecordImpl.java:124)    at ch.tosca.common.repository.JooqRepositoryTest.insertKampartikel(JooqRepositoryTest.java:66)    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)   ... 48 more我读过有关驱动程序不兼容的 GitHub 问题,但数据库和驱动程序 ojdbc8 都是版本 12.2.0.1.0我们做错了什么?
查看完整描述

1 回答

?
呼啦一阵风

TA贡献1802条经验 获得超6个赞

以下是使用普通 JDBC 重现它的方法:

如何重现它

使用此表

CREATE TABLE T (

  ID NUMBER(7),

  CONSTRAINT pk PRIMARY KEY (ID)

);

在内部使用Connection.prepareStatement(String, String[])重载,例如 jOOQ 所做的:


try (Connection c = dbSetup.getConnection()) {

    try (PreparedStatement s = c.prepareStatement(

        "insert into \"TEST\".\"T\" (\"ID\") values (?)", new String[] { "ID" })) {

        s.setInt(1, 1);

        s.execute ();

    }

}

解决方法

不要引用架构名称:


try (Connection c = dbSetup.getConnection()) {

    try (PreparedStatement s = c.prepareStatement(

        "insert into TEST.\"T\" (\"ID\") values (?)", new String[] { "ID" })) {

        s.setInt(1, 1);

        s.execute ();

    }

}

完全避免资格:


try (Connection c = dbSetup.getConnection()) {

    try (PreparedStatement s = c.prepareStatement(

        "insert into \"T\" (\"ID\") values (?)", new String[] { "ID" })) {

        s.setInt(1, 1);

        s.execute ();

    }

}

使用 jOOQ 中的解决方法:

  • 您可以使用关闭模式限定Settings.renderSchema

  • 您可以使用关闭标识符的引用Settings.renderQuotedNames

查看完整回答
反对 回复 2023-08-23
  • 1 回答
  • 0 关注
  • 164 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信