尝试传递自定义oracle类型对象映射时无效的名称模式

时间:2014-02-05 21:43:00

标签: java oracle plsql spring-jdbc oracle-type

Java spring自定义Oracle类型作为参数并获得跟随错误。

我不明白无效名称模式是什么意思?

感谢任何帮助。

org.springframework.jdbc.UncategorizedSQLException: 
### Error updating database.  Cause: java.sql.SQLException: invalid name pattern: UPSELL.mkt_list_tab
### The error may involve com.comcast.upsell.dao.ProviderAndRegionalDao.getCorpsToMarketsList-Inline
### The error occurred while setting parameters
### SQL: call upsell_tx_etl_report.GET_OFFER_CORPS_TO_MARKETS(   ?,   ?,   ?   )
### Cause: java.sql.SQLException: invalid name pattern: MY_SCHEMA.mkt_list_tab
; uncategorized SQLException for SQL []; SQL state [99999]; error code [17074]; invalid name pattern: MY_SCHEMA.mkt_list_tab; nested exception is java.sql.SQLException: invalid name pattern: MY_SCHEMA.mkt_list_tab
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:83)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
    at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:71)
    at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:364)
    at com.sun.proxy.$Proxy15.update(Unknown Source)

以下是我的oracle类型decleration

create or replace 
type mkt_list_tab is table of mkt_list_rec

create or replace 
type mkt_list_rec as object
    (
    market  VARCHAR2(100)
    )

Procedure call as following
PROCEDURE GET_OFFER_CORPS_TO_MARKETS(p_division              IN VARCHAR2, --ALL/Particular
                                     p_market_list           IN mkt_list_tab,
                                     o_offer_corp_market_cur OUT SYS_REFCURSOR)

这是我的java类型处理程序

    public class MarketListTypeHandler implements TypeHandler {



        @SuppressWarnings("unchecked")
        @Override
        public void setParameter(PreparedStatement ps, int i, Object parameter, JdbcType jdbcType) throws SQLException {


            C3P0NativeJdbcExtractor cp30NativeJdbcExtractor = new C3P0NativeJdbcExtractor(); 
            OracleConnection connection = (OracleConnection) cp30NativeJdbcExtractor.getNativeConnection(ps.getConnection()); 


            List<StoredProcedurePojo> objects = (List<StoredProcedurePojo>) parameter;

            StructDescriptor structDescriptor = StructDescriptor.createDescriptor("mkt_list_rec", connection);

            STRUCT[] structs = new STRUCT[objects.size()];
            for (int index = 0; index < objects.size(); index++)
            {
                StoredProcedurePojo pack = objects.get(index);
                Object[] params = new Object[2];
                params[0] = pack.getMarket();
                STRUCT struct = new STRUCT(structDescriptor, ps.getConnection(), params);
                structs[index] = struct;
            }

            ArrayDescriptor desc = ArrayDescriptor.createDescriptor("mkt_list_tab", ps.getConnection());
            ARRAY oracleArray = new ARRAY(desc, ps.getConnection(), structs);
            ps.setArray(i, oracleArray);
        }


@Override
        public Object getResult(ResultSet arg0, String arg1) throws SQLException {
            // TODO Auto-generated method stub
            return null;
        }

        @Override
        public Object getResult(ResultSet arg0, int arg1) throws SQLException {
            // TODO Auto-generated method stub
            return null;
        }

        @Override
        public Object getResult(CallableStatement arg0, int arg1) throws SQLException {
            // TODO Auto-generated method stub
            return null;
        }



        public MarketListTypeHandler() {
            super();
            // TODO Auto-generated constructor stub
        }
}

这是我的存储过程pojo类

public class StoredProcedurePojo {


    private String market;

    public String getMarket() {
        return market;
    }

    public void setMarket(String market) {
        this.market = market;
    }


}

我正在尝试遵循以下解决方案

How to Pass Java List of Objects to Oracle Stored Procedure Using MyBatis?

3 个答案:

答案 0 :(得分:23)

您用于应用的oracle用户ID无权访问MY_SCHEMA.mkt_list_tab类型。

同时确保以下几点。

1)您的描述符调用中必须包含MY_SCHEMA.MKT_LIST_TAB等所有大写字母。
2)如果您不在代码中使用模式名称,并且您的app id与不同的模式相关联,那么最好为该类型(父级和子级)创建PUBLIC SYNONYM,并授予{{1您的应用程序ID的权限,否则,在代码中使用模式名称。(仍然需要提供权限)

答案 1 :(得分:5)

两件事之一:

  • 您要连接到数据库的oracle用户没有执行存储过程的权限(不太可能)
  • 您的ArrayDescriptor和StructDescriptor应分别以大写形式显示“mkt_list_tab”和“mkt_list_rec”。 (更有可能)

更新:This question与您的相似。

答案 2 :(得分:1)

我在调用Oracle存储过程时遇到了同样的问题。

PACKAGE_NAME.PROCEDURE_NAME(?,?,?,?,?,?,?,?,?)}];

13:52:24.202 [main] DEBUG o.s.j.s.SQLStateSQLExceptionTranslator - 提取的SQL状态类'99' 来自值'99999'org.springframework.jdbc.UncategorizedSQLException:CallableStatementCallback; 未分类SQL的SQLException [{call PACKAGE_NAME.PROCEDURE_NAME(?,?,?,?,?,?,?,?,?)}]; SQL状态[99999];错误代码[17074];无效的名称模式:SCHEMA.Type_Param;嵌套异常是java.sql.SQLException: 无效的名称模式:SCHEMA.Type_Param         在org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:83)         在org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)         在org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)         在org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:1036)         在org.springframework.jdbc.core.JdbcTemplate.call(JdbcTemplate.java:1070)         在org.springframework.jdbc.object.StoredProcedure.execute(StoredProcedure.java:144)

我的程序是采用1表类型输入参数。此参数是在包级别范围定义的。因此,我将此包级别范围参数移至Schema级别参数并解决了该问题。

无法直接从java中访问包中创建的PLSQL类型。