Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
16.09.2009, 13:53
|
|||
|---|---|---|---|
|
|||
DB2 + Java + PreparedStatement |
|||
|
#18+
Есть функция в DB2 : DOKLAD.DATEOFVN(VAR0 DATE,VAR1 INTEGER) RETURNS DATE ..... (функция возвращает нужную дату в зависимости от параметра VAR1 c учётом даты VAR0) при выполнении следующего запроса - всё отработает select DOKLAD.DATEOFVN(DATE('2009-09-01'),1) from sysibm.sysdummy1; в программе пытаюсь сделать так : String DV = '2009-09-01'; String sqlREL = "select DOKLAD.DATEOFVN(DATE(?),1) from sysibm.sysdummy1" PreparedStatement pstmtREL = conn.prepareStatement(sqlREL); pstmtREL.setString (1, DV); ResultSet RES = pstmtREL.executeQuery(); // ВОТ ТУТ ВЫЛЕТАЕТ с SQLCODE: -418, SQLSTATE: 42610, SQLERRMC: null подскажите в чём ошибка - пробовал и так pstmtREL.setDate (1, Date.StringOf(DV)); - тоже самое... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
16.09.2009, 15:22
|
|||
|---|---|---|---|
DB2 + Java + PreparedStatement |
|||
|
#18+
Слободской АндрейЕсть функция в DB2 : DOKLAD.DATEOFVN(VAR0 DATE,VAR1 INTEGER) RETURNS DATE ..... (функция возвращает нужную дату в зависимости от параметра VAR1 c учётом даты VAR0) при выполнении следующего запроса - всё отработает select DOKLAD.DATEOFVN(DATE('2009-09-01'),1) from sysibm.sysdummy1; в программе пытаюсь сделать так : String DV = '2009-09-01'; String sqlREL = "select DOKLAD.DATEOFVN(DATE(?),1) from sysibm.sysdummy1" PreparedStatement pstmtREL = conn.prepareStatement(sqlREL); pstmtREL.setString (1, DV); ResultSet RES = pstmtREL.executeQuery(); // ВОТ ТУТ ВЫЛЕТАЕТ с SQLCODE: -418, SQLSTATE: 42610, SQLERRMC: null подскажите в чём ошибка - пробовал и так pstmtREL.setDate (1, Date.StringOf(DV)); - тоже самое... ЗдесьСлободской АндрейString DV = '2009-09-01'; кавычки двойные или одинарные? И потом, раз ваша функция что-то возвращает, то, наверное, надо использовать CallableStatement вместо PreparedStatement с регистрацией возвращаемого параметра. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
16.09.2009, 15:55
|
|||
|---|---|---|---|
|
|||
DB2 + Java + PreparedStatement |
|||
|
#18+
Слободской Андрей, Попробуйте так: String sqlREL = "select DOKLAD.DATEOFVN(DATE( cast(? as varchar(10)) ),1) from sysibm.sysdummy1" ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
17.09.2009, 07:41
|
|||
|---|---|---|---|
|
|||
DB2 + Java + PreparedStatement |
|||
|
#18+
Mark Barinstein, Спасибо! :) - заработало :) как жёский контроль типов оказывается. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
18.09.2009, 10:13
|
|||
|---|---|---|---|
|
|||
DB2 + Java + PreparedStatement |
|||
|
#18+
Слободской Андрей, дело в том, что у ф-ции DATE может быть параметр 3-х типов, а на этапе prepare тип данных надо знать. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=43&mobile=1&tid=1603086]: |
0ms |
get settings: |
10ms |
get forum list: |
10ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
173ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
44ms |
get tp. blocked users: |
1ms |
| others: | 279ms |
| total: | 538ms |

| 0 / 0 |
