Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Вызов хранимой процедуры со смешанным ответом. Вызов хранимки через jdbc с return и rs 
V
    Опции темы
eandy
Дата 19.10.2009, 19:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 21
Регистрация: 18.4.2007

Репутация: нет
Всего: нет



Приветствую.

Как получить все результаты отработки следующей sybase хранимки?

CREATE PROCEDURE dbo.doIsDayOpen
As
BEGIN
    SELECT 999 AS var1
    RETURN 777
END

---

return могу получить так

        String command = "{? = call dbo.doIsDayOpen()}";
        CallableStatement callableStatement = connection.prepareCall(command);
        callableStatement.registerOutParameter(1, Types.INTEGER);
...
            callableStatement.execute();

            callableStatement.getInt(1)  // возвращает return

... далее пытаюсь 
            ResultSet resultSet = callableStatment.getResultSet();
            if(resultSet.next()) {
                resultSet.getInt(0); //вроде как должен получить 999, но падает с эксепшеном
            }

Добавлено через 14 минут и 13 секунд
Ура... это волшебный форум smile)) Пока не написал сюда - часа 4 с бубном танцевал...

Вобщем, проблема в том, что ResultSet нужно получать раньше чем return. Иначе после получения return что-то где-то закрывается.

То есть:

        String command = "{? = call dbo.doIsDayOpen()}";
        CallableStatement callableStatement = connection.prepareCall(command);
        callableStatement.registerOutParameter(1, Types.INTEGER);
            callableStatement.execute();


... сначала
            ResultSet resultSet = callableStatment.getResultSet();
            if(resultSet.next()) {
                resultSet.getInt(0); //вроде как должен получить 999, но падает с эксепшеном
            }

... потом

            callableStatement.getInt(1)  // возвращает return


Это сообщение отредактировал(а) eandy - 19.10.2009, 19:22
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0896 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.