首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >调用存储过程时的SQLCODE:-3015

调用存储过程时的SQLCODE:-3015
EN

Stack Overflow用户
提问于 2016-06-21 03:15:25
回答 1查看 1.5K关注 0票数 0

我有一个存储过程如下:

代码语言:javascript
复制
CREATE OR REPLACE PROCEDURE "SMEADM"."COPY_TABLE_WITH_FILTER"
(IN IN_SOURCE_TABLE_NAME VARCHAR(50), IN IN_DEST_TABLE_NAME VARCHAR(50), IN IN_WHERE_CONDITION VARCHAR(1024))
NOT DETERMINISTIC
LANGUAGE SQL
SPECIFIC SQL_SME_DATA_RETENTION
BEGIN

  CALL SYSPROC.ADMIN_CMD('LOAD FROM (SELECT * FROM ' || IN_SOURCE_TABLE_NAME || ' WHERE ' || IN_WHERE_CONDITION || ' ) of cursor insert into ' || IN_DEST_TABLE_NAME || ' nonrecoverable');

END
@

下面是我调用这个存储过程的java代码:

代码语言:javascript
复制
public void copyData(String srcTableName, String bakTableName, String dateColName, String sqlDateStr) 
{
    String sqlWhereFilter = " date(" + dateColName + ") < date('" + sqlDateStr + "')";

    SimpleJdbcCall jdbcCall = new SimpleJdbcCall(this)
                .withSchemaName("SMEADM")
                .withProcedureName("COPY_TABLE_WITH_FILTER");

    SqlParameterSource in = new MapSqlParameterSource()
                                    .addValue("IN_SOURCE_TABLE_NAME", srcTableName)
                                    .addValue("IN_DEST_TABLE_NAME", bakTableName)
                                    .addValue( "IN_WHERE_CONDITION", sqlWhereFilter );

    jdbcCall.execute(in);
}

在我当地的环境中,无论是坐环境还是UAT环境,一切都很好。

但是我在生产环境中得到了一个SqlException。下面是我的堆栈跟踪:

代码语言:javascript
复制
[16-06-17 00:13:30] com.cv.ibs.batch.dao.impl.DataRetentionDAOImpl DEBUG: | Calling stored procedure [{call SMEADM.COPY_TABLE_WITH_FILTER(?, ?, ?)}]
[16-06-17 00:13:31] org.springframework.batch.core.step.AbstractStep ERROR: | Encountered an error executing the step
org.springframework.jdbc.UncategorizedSQLException: CallableStatementCallback; uncategorized SQLException for SQL [{call SMEADM.COPY_TABLE_WITH_FILTER(?, ?, ?)}]; SQL state [     ]; error code [-3015]; DB2 SQL error: SQLCODE: -3015, SQLSTATE:      , SQLERRMC: -551; nested exception is com.ibm.db2.jcc.c.SqlException: DB2 SQL error: SQLCODE: -3015, SQLSTATE:      , SQLERRMC: -551
    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.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:969)
    at org.springframework.jdbc.core.JdbcTemplate.call(JdbcTemplate.java:1003)
    at org.springframework.jdbc.core.simple.AbstractJdbcCall.executeCallInternal(AbstractJdbcCall.java:391)
    at org.springframework.jdbc.core.simple.AbstractJdbcCall.doExecute(AbstractJdbcCall.java:354)
    at org.springframework.jdbc.core.simple.SimpleJdbcCall.execute(SimpleJdbcCall.java:181)
    at com.cv.ibs.batch.dao.impl.DataRetentionDAOImpl.copyData(DataRetentionDAOImpl.java:38)
    at com.cv.ibs.batch.job.tasklet.DataRetentionCopyOldDataTasklet.execute(DataRetentionCopyOldDataTasklet.java:41)
    at org.springframework.batch.core.step.tasklet.TaskletStep$ChunkTransactionCallback.doInTransaction(TaskletStep.java:386)
    at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:130)
    at org.springframework.batch.core.step.tasklet.TaskletStep$2.doInChunkContext(TaskletStep.java:264)
    at org.springframework.batch.core.scope.context.StepContextRepeatCallback.doInIteration(StepContextRepeatCallback.java:76)
    at org.springframework.batch.repeat.support.RepeatTemplate.getNextResult(RepeatTemplate.java:367)
    at org.springframework.batch.repeat.support.RepeatTemplate.executeInternal(RepeatTemplate.java:214)
    at org.springframework.batch.repeat.support.RepeatTemplate.iterate(RepeatTemplate.java:143)
    at org.springframework.batch.core.step.tasklet.TaskletStep.doExecute(TaskletStep.java:250)
    at org.springframework.batch.core.step.AbstractStep.execute(AbstractStep.java:195)
    at org.springframework.batch.core.job.SimpleStepHandler.handleStep(SimpleStepHandler.java:135)
    at org.springframework.batch.core.job.flow.JobFlowExecutor.executeStep(JobFlowExecutor.java:61)
    at org.springframework.batch.core.job.flow.support.state.StepState.handle(StepState.java:60)
    at org.springframework.batch.core.job.flow.support.SimpleFlow.resume(SimpleFlow.java:144)
    at org.springframework.batch.core.job.flow.support.SimpleFlow.start(SimpleFlow.java:124)
    at org.springframework.batch.core.job.flow.FlowJob.doExecute(FlowJob.java:135)
    at org.springframework.batch.core.job.AbstractJob.execute(AbstractJob.java:281)
    at org.springframework.batch.core.launch.support.SimpleJobLauncher$1.run(SimpleJobLauncher.java:120)
    at org.springframework.core.task.SyncTaskExecutor.execute(SyncTaskExecutor.java:48)
    at org.springframework.batch.core.launch.support.SimpleJobLauncher.run(SimpleJobLauncher.java:114)
    at com.cv.ibs.batch.job.DataRetentionJob.execute(DataRetentionJob.java:56)
    at com.cv.ibs.batch.job.BatchProcess.run(BatchProcess.java:99)
    at com.cv.ibs.batch.job.launcher.DataRetentionLauncher.main(DataRetentionLauncher.java:36)
Caused by: 
com.ibm.db2.jcc.c.SqlException: DB2 SQL error: SQLCODE: -3015, SQLSTATE:      , SQLERRMC: -551
    at com.ibm.db2.jcc.c.fg.d(fg.java:1340)
    at com.ibm.db2.jcc.b.gb.k(gb.java:351)
    at com.ibm.db2.jcc.b.gb.e(gb.java:96)
    at com.ibm.db2.jcc.b.w.e(w.java:83)
    at com.ibm.db2.jcc.b.vb.i(vb.java:164)
    at com.ibm.db2.jcc.c.fg.q(fg.java:1311)
    at com.ibm.db2.jcc.c.gg.d(gg.java:2386)
    at com.ibm.db2.jcc.c.hg.X(hg.java:115)
    at com.ibm.db2.jcc.c.hg.execute(hg.java:98)
    at org.apache.commons.dbcp.DelegatingPreparedStatement.execute(DelegatingPreparedStatement.java:169)
    at org.springframework.jdbc.core.JdbcTemplate$5.doInCallableStatement(JdbcTemplate.java:1005)
    at org.springframework.jdbc.core.JdbcTemplate$5.doInCallableStatement(JdbcTemplate.java:1)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:953)
    ... 28 more
[main] ERROR c.cv.ibs.batch.job.DataRetentionJob - [BATCH] Error on executing the batch job
com.cv.ibs.cib.bulkpayment.BatchProcessException: Error in spring batch process, please checklog file and BatchFailedDetails table.
    at com.cv.ibs.batch.job.DataRetentionJob.execute(DataRetentionJob.java:60) ~[com.cv.ibs.batch.jar:na]
    at com.cv.ibs.batch.job.BatchProcess.run(BatchProcess.java:99) [com.cv.ibs.batch.jar:na]
    at com.cv.ibs.batch.job.launcher.DataRetentionLauncher.main(DataRetentionLauncher.java:36) [com.cv.ibs.batch.jar:na]

我怀疑此异常是由于我没有授予db用户的某些访问权限所致。因此,我尝试从SIT环境中的db用户获取一些访问权限(例如,加载数据库等等),试图触及相同的异常。然而,在SIT中,我碰到了其他错误,这清楚地告诉了我什么是根本原因,而不是错误代码-3015。

试图从谷歌那里得到一些提示,但失败了。我想我错过了找出根本原因的一些要点/步骤。敬请指教。

EN

回答 1

Stack Overflow用户

发布于 2016-06-21 04:43:48

您可以使用DB2命令行获取有关错误的详细信息,只需从异常中使用SQL,删除减号并将其放入零(在开始时,如果它较短,为4):

代码语言:javascript
复制
db2 ? sql3015

SQL3015N在处理过程中发生了一个SQL错误。 解释: 在实用程序调用期间发生SQL错误。 该实用程序停止处理。 用户回复: 有关更多信息,请查看消息中的SQLCODE (消息号)。进行更改并重新提交命令。

我假设SQLERRMC: -551是存储过程中发生的错误,即:

代码语言:javascript
复制
db2 ? sql0551

SQL0551N语句失败,因为授权ID没有执行操作所需的授权或特权。授权ID:"“。行动:"“。目的:"“。

更多关于这个错误的这里

遗憾的是,最初的消息并没有给出很多关于授权-ID和操作等的信息。

自己在代码中捕获SqlException,看看getNextException() (javadoc)是否会给您提供更多信息。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37934976

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档