2016-06-21 6 views
0

У меня есть хранимая процедура следующим образом:SQLCODE: -3015 при вызове хранимой процедуры

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-код для вызова этой хранимой процедуры:

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); 
} 

Все работает отлично в моя локальная среда, среда SIT и среда UAT.

Но я получаю SqlException в производственной среде. Ниже мой трассировки стека:

[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, пытаясь добиться того же исключения. Тем не менее, в SIT, я нахожу другую ошибку, которая ясно говорит мне, что является основной причиной, а не код ошибки -3015

Попытка получить некоторый намек от Google, но не удалось. Я думаю, что я пропустил некоторые моменты/шаги, чтобы найти основную причину. Добрый совет.

+0

Ваша процедура открыта для SQL Injection; предоставлено, что-то вроде этого потребует динамического SQL, но вы должны проверить, что имена таблиц и столбец являются фактическими именами столбцов и таблиц (вероятно, из хранимой процедуры). Было бы лучше передать параметр даты как фактический тип даты (желательно что-то из новой библиотеки java.time). Вероятно, вы хотите явно установить уровень параллелизма. Кроме того, если это возможно, не добавляйте столбец сравнения на сегодняшний день в SQL, поскольку это может привести к тому, что система игнорирует индексы. –

ответ

0

Вы можете использовать командную строку DB2 для получения подробной информации об ошибке, просто используйте SQL-код из Exception, удалите знак минус и нанесите его нулями (в начале, если его короче 4) :

db2 ? sql3015 

SQL3015N ошибка SQL "<SQLCODE>" произошло во время обработки. произошло

SQL-ошибка во время вызова утилиты:

Объяснение.

Утилита прекращает обработку.

Действия пользователя:

Посмотрите на SQLCODE (номер сообщения) в сообщении для получения дополнительной информации . Внесите изменения и повторно отправьте команду.

Я предполагаю, что SQLERRMC: -551 это ошибка, что случилось в вашей хранимой процедуры, которая:

db2 ? sql0551 

SQL0551N Оператор не удалась, поскольку ID авторизации не иметь требуемое разрешение или привилегии выполните операцию . Идентификатор авторизации: «< авторизация-ID >». Операция: "< эксплуатация >". Объект: «< имя объекта >».

Подробнее об этой ошибке here.

К сожалению, первоначальное сообщение не дает много информации об идентификаторе авторизации и операции и т. Д.

Соберите SqlException самостоятельно в вашем коде и посмотрите, если getNextException() (javadoc) предоставит вам больше информации.