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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Трабл в MySQL, Не пинайте в БД, я думаю что мне сюда :) 
:(
    Опции темы
Zandr
Дата 26.2.2005, 11:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



j2sdk1.4.2_04
MySQL 4.1.10
mysql-connector-java-3.1.7
Таблица:
Код

create table lek (
 lekId integer auto_increment primary key,
 lek varchar(255)
);

Код:
Код

PreparedStatement ps = conn.prepareStatement(
       "insert into lek (lek) values (?)",
       PreparedStatement.RETURN_GENERATED_KEYS);
...
ps.setString( 1, "Анальгин");
// Здесь мы абсолютно уверены, что в таблице еще нет анальгина
ps.executeUpdate();
ResultSet idRs = ps.getGeneratedKeys();
if (idRs.next()) {
   // Вот тут idStr становится [b]null[/b]
   String idStr = rs.getString( 1);
} else {
   System.err.println( "ID почему-то не получен...");
}


Как правильно получить свежесозданный id?

PM MAIL   Вверх
LSD
Дата 26.2.2005, 12:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



У Oracle есть такая фишка как returning, которая позволяет получить значение поля после проведения DML. Может и в MySQL, нечто похожее есть?


--------------------
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   Вверх
Zandr
Дата 26.2.2005, 13:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



В мускле есть функция LAST_INSERT_ID(), которая дает то что нужно. Либо (если не путаю) сразу после выполнения INSERT можно получить этот самый id так:
Код

select lekId from lek where lekId=null;

проблема в том, что это от лукавого все smile
во-первых делать два явных запроса, во-вторых СУБД-зависимо...
PM MAIL   Вверх
LSD
Дата 26.2.2005, 13:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



Может эта функция не реализованна в драйверах MySQL? Проверю на 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   Вверх
LSD
Дата 26.2.2005, 13:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


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

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



Я проверил, у Oracle данная функция просто не реализованна, о чем он радостно сообщает. Я думаю у MySQL та же фигня.


--------------------
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   Вверх
Zandr
Дата 28.2.2005, 08:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



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

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

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


 




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


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

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