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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как передать java.sql.Date в запрос? 
:(
    Опции темы
Andrey1
Дата 7.5.2008, 10:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



В таблице есть столбцы типа DATE (first_taken, latest_taken) и нужно выбрать все записи, временной интервал которых содержит заданное время. 

Java выдает время в формате:

Код

Wed May 07 10:42:35 MSD 2008


Запрос типа
"SELECT * FROM MY_TABLE WHERE first_taken <  ?  AND latest_taken >= ?" 

если в него передать дату как объект не работает:
Код

...
        statement = conn.prepareStatement(query);
        statement.setDate(1,(java.sql.Date) time);
        statement.setDate(2,(java.sql.Date) time);
...


Почему то не работает и стандартный шаблон:

Код

select to_date('Tue May 06 18:47:29 MSD 2008'
, 'DY Mon DD HH24:MI:SS TZD YYYY', 'NLS_DATE_LANGUAGE = AMERICAN') from dual;

Ошибка: 
Error report:
SQL Error: ORA-01821: date format not recognized
01821. 00000 -  "date format not recognized"

Хотя
Код

select to_date('Tue May 06 18:47:29 2008'
, 'DY Mon DD HH24:MI:SS YYYY', 'NLS_DATE_LANGUAGE = AMERICAN') from dual;

работает.

Собсно сабж...

Это сообщение отредактировал(а) Andrey1 - 7.5.2008, 10:42


--------------------
Созерцание и мудрость - едины. Соцерцание - это основа мудрости, а мудрость - это функция (т.е. умение использовать) созерцания.
из сутры помоста шестого патриарха Хуэйнена
PM MAIL WWW ICQ   Вверх
batigoal
Дата 7.5.2008, 10:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

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



Цитата(Andrey1 @  7.5.2008,  11:00 Найти цитируемый пост)
        statement = conn.prepareStatement(query);
        statement.setDate(1,(java.sql.Date) time);
        statement.setDate(1,(java.sql.Date) time);

Ну, во-первых, тут опечатка - в последней строке должно быть 2, а не 1. Во-вторых, каков тип переменной time, что тебе приходится его явно приводить?


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
Andrey1
Дата 7.5.2008, 10:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Очепятку исправил.

java.util.Date там было...


--------------------
Созерцание и мудрость - едины. Соцерцание - это основа мудрости, а мудрость - это функция (т.е. умение использовать) созерцания.
из сутры помоста шестого патриарха Хуэйнена
PM MAIL WWW ICQ   Вверх
Andrey1
Дата 7.5.2008, 10:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Вообщем, решил проблему форматированием даты: 

Код

new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(date)



--------------------
Созерцание и мудрость - едины. Соцерцание - это основа мудрости, а мудрость - это функция (т.е. умение использовать) созерцания.
из сутры помоста шестого патриарха Хуэйнена
PM MAIL WWW ICQ   Вверх
DimW
Дата 7.5.2008, 11:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1330
Регистрация: 24.2.2005
Где: Орёл

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



Цитата(Andrey1 @  7.5.2008,  10:00 Найти цитируемый пост)
Собсно сабж...

я передаю так:
Код

DateFormat formatter = new java.text.SimpleDateFormat("dd.MM.yyyy");
java.util.Date date = (java.util.Date)formatter.parse("01.02.2008");
stmt.setDate(1, new java.sql.Date(date.getTime()));


а почему вопрос в эту ветку?
PM MAIL ICQ   Вверх
LSD
Дата 7.5.2008, 12:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Модератор: перемещено из Oracle.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Andrey1
Дата 7.5.2008, 13:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата(DimW @  7.5.2008,  11:09 Найти цитируемый пост)
а почему вопрос в эту ветку? 

Вопрос на стыке тем по Ораклу и Java smile...


--------------------
Созерцание и мудрость - едины. Соцерцание - это основа мудрости, а мудрость - это функция (т.е. умение использовать) созерцания.
из сутры помоста шестого патриарха Хуэйнена
PM MAIL WWW ICQ   Вверх
LSD
Дата 7.5.2008, 13:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Цитата(Andrey1 @  7.5.2008,  14:03 Найти цитируемый пост)
Вопрос на стыке тем по Ораклу и Java

К Oracle он имеет минимальное отношение, работа с БД в Java для разных СУБД отличается минимально.

Самый нормальный вариант это:
Код

stmt.setDate(1, new java.sql.Date(date.getTime()));

а форматирование даты это извращение.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Andrey1
Дата 8.5.2008, 14:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата(LSD @  7.5.2008,  13:19 Найти цитируемый пост)
Самый нормальный вариант это:

И есть гарантии, что 
(1) сравнение типа " where column < ?" - работает (у меня такой вариант помнится не работал)?
(2) new java.sql.Date(date.getTime()) - сохранит время (такое впечатление, что так сохранится только дата)?

Это сообщение отредактировал(а) Andrey1 - 8.5.2008, 14:10


--------------------
Созерцание и мудрость - едины. Соцерцание - это основа мудрости, а мудрость - это функция (т.е. умение использовать) созерцания.
из сутры помоста шестого патриарха Хуэйнена
PM MAIL WWW ICQ   Вверх
LSD
Дата 8.5.2008, 14:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Цитата(Andrey1 @  8.5.2008,  15:10 Найти цитируемый пост)
И есть гарантии, что 
(1) сравнение типа " where column < ?" - работает (у меня такой вариант помнится не работал)?
(2) new java.sql.Date(date.getTime()) - сохранит время (такое впечатление, что так сохранится только дата)?

Не работал он мог по двум причинам: 
- ты где-то накосячил
- неверный тип, java.sql.Date вообще говоря предназначен для хранения только даты (хотя на самом деле хранить и дату и время), используй вместо него java.sql.Timestamp


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
marhatter
Дата 28.3.2013, 20:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Здравствуйте. У меня подобная проблем. Пытаюсь сделать так
Код

DateFormat formatter = new java.text.SimpleDateFormat("dd.MM.yyyy");
java.util.Date date = (java.util.Date)formatter.parse("01.02.2008");
                
Properties properties = new Properties();
properties.setProperty("charSet", "cp866");
properties.setProperty("CODEPAGEID", "66");
Class.forName("com.hxtt.sql.dbf.DBFDriver");
String connString = "jdbc:DBF:/" + System.getProperty("user.dir") + "\\";
connection = DriverManager.getConnection(connString, properties);
String sql = "INSERT INTO KS (PERS_NUM, DATEZ, GLOBLIB, LOCLIB) VALUES("+str[1]+", ?, "+str[2]+", "+str[3]+" )";
stmt = connection.prepareStatement(sql);
stmt.setDate(1, new java.sql.Date(date.getTime()));
stmt.executeUpdate(sql);

Выдает ошибку
Код

java.sql.SQLException: Failed to get a string value from com.hxtt.d.e: ?
at com.hxtt.global.SQLState.SQLException(Unknown Source)
at com.hxtt.global.SQLState.transferValueException(Unknown Source)
at com.hxtt.global.ac.for(Unknown Source)
at com.hxtt.global.ac.a(Unknown Source)
    at com.hxtt.global.ac.d(Unknown Source)
    at com.hxtt.sql.dbf.i.a(Unknown Source)
    at com.hxtt.sql.dbf.i.a(Unknown Source)
    at com.hxtt.sql.dbf.i.if(Unknown Source)
    at com.hxtt.sql.dbf.i.a(Unknown Source)
    at com.hxtt.sql.cp.do(Unknown Source)
    at com.hxtt.sql.eh.int(Unknown Source)
    at com.hxtt.sql.de.a(Unknown Source)
    at com.hxtt.sql.bm.a(Unknown Source)
    at com.hxtt.sql.ag.a(Unknown Source)
    at com.hxtt.sql.ag.a(Unknown Source)
    at com.hxtt.sql.ag.a(Unknown Source)
    at com.hxtt.sql.ag.executeUpdate(Unknown Source)
    at arm_ks.ARM_KS.InsertTab(ARM_KS.java:174)
    at arm_ks.ARM_KS.main(ARM_KS.java:30)

не нравится знак "?". 
Если указывать явно
Код

String sql = "INSERT INTO KS (PERS_NUM, DATEZ, GLOBLIB, LOCLIB) VALUES("+str[1]+","+ new java.sql.Date(date.getTime())+", "+str[2]+", "+str[3]+" )";

То вставляется значение 01.01.1970
Как передать параметр в запрос? Или остается только использовать дургой драйвер?

Это сообщение отредактировал(а) marhatter - 28.3.2013, 21:08
PM MAIL   Вверх
LSD
Дата 29.3.2013, 12:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Напиши тест с одним полем типа дата. Если ошибка останется, пиши в поддрежку, это же все таки коммерческий продукт, пусть отрабатывают свои деньги.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

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

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


 




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


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

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