Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Получение ID записи. (UNIQUE)

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Dragon_Knight
Отправлено: 04 Июня, 2012 - 20:00:33
Post Id



Гость


Покинул форум
Сообщений всего: 103
Дата рег-ции: Май 2012  
Откуда: г.Мытищи, МО


Помог: 0 раз(а)




Всем привет, опять застрял на, казалось-бы, простой вещи.

Задача такова:
Есть таблица с индексом UNIQUE.
CODE (SQL):
скопировать код в буфер обмена
  1. CREATE TABLE IF NOT EXISTS `fmr_title` (
  2.   `id` int(11) NOT NULL AUTO_INCREMENT,
  3.   `title` varchar(100) NOT NULL,
  4.   PRIMARY KEY (`id`),
  5.   UNIQUE KEY `title_key` (`title`)
  6. ) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

Нужно вставлять уникальное значение поля `title`, при этом, независимо от того, вставили мы значение или оно уже есть, нужно получить ID этой записи.

Вставить и получить ID я знаю как: 'mysql_ insert_ id', но как более грамотно получиться ID поля, которое уже есть?

(Отредактировано автором: 04 Июня, 2012 - 20:05:47)

 
 Top
Мелкий Супермодератор
Отправлено: 04 Июня, 2012 - 20:55:30
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




MySQL? А, глупый вопрос, MyISAM же.

Одним запросом не выйдет. Делайте select, если строки нет - insert. Ну или наоборот, insert ignore, если affected rows ==0, то select.
Хотя, может получится хранимой процедурой.


-----
PostgreSQL DBA
 
 Top
Dragon_Knight
Отправлено: 04 Июня, 2012 - 21:10:50
Post Id



Гость


Покинул форум
Сообщений всего: 103
Дата рег-ции: Май 2012  
Откуда: г.Мытищи, МО


Помог: 0 раз(а)




Мелкий, т.е. в таком случае есть смысл убрать и не использовать "UNIQUE KEY `title_key` (`title`)"?
 
 Top
Мелкий Супермодератор
Отправлено: 04 Июня, 2012 - 21:57:23
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Да нет, уникальные индексы очень эффективны на выборках. А как минимум 1 выборка у вас по нему есть.
Ну и это просто хороший вариант самодокументации и защиты от случайных правок.


-----
PostgreSQL DBA
 
 Top
Dragon_Knight
Отправлено: 04 Июня, 2012 - 22:11:28
Post Id



Гость


Покинул форум
Сообщений всего: 103
Дата рег-ции: Май 2012  
Откуда: г.Мытищи, МО


Помог: 0 раз(а)




Мелкий, спасибо за ответ. Тока я видимо что-то недопонял...
Я сделал такую функцию:
PHP:
скопировать код в буфер обмена
  1. function MySQL_InsertAndReturnID($table, $key, $value)
  2. {
  3.         $query_1 = mysql_query("SELECT `id` FROM `" . $table . "` WHERE `" . $key . "` = '" . $value . "' LIMIT 1");
  4.         if($query_1 == TRUE)
  5.         {
  6.                 if(mysql_num_rows($query_1) == 1) // Найдено
  7.                 {
  8.                         $row = mysql_fetch_row($query_1);
  9.                         $ID = $row['0'];
  10.                 }
  11.                 else // НЕ найдено
  12.                 {
  13.                         $query_2 = mysql_query("INSERT INTO `" . $table . "` SET `" . $key . "` = '" . $value . "'");
  14.                         if($query_2 == TRUE)
  15.                         {
  16.                                 $ID = mysql_insert_id();
  17.                         }
  18.                 }
  19.         }
  20.  
  21.         return $ID;
  22. }

Все остальные запросы на таблицу будут иметь вить типа:
SELECT `title` FROM `fmr_title` WHERE `id` = '" . $Title_ID . "'.
 
 Top
Мелкий Супермодератор
Отправлено: 05 Июня, 2012 - 09:21:34
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Тупая таблица-справочник на 2 поля что ли?
Если новые вставки будут редко, тогда да, уникальный индекс можно и выкинуть.


-----
PostgreSQL DBA
 
 Top
Dragon_Knight
Отправлено: 05 Июня, 2012 - 16:30:15
Post Id



Гость


Покинул форум
Сообщений всего: 103
Дата рег-ции: Май 2012  
Откуда: г.Мытищи, МО


Помог: 0 раз(а)




Мелкий, да. Новые вставки в начале будут частыми, но со временем сойдут на нет вообще и будет только чтение.

Спасибо за помощь. Улыбка

PS> С какого кол-во сообщений можно говорить "Спасибо!"?
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Работа с СУБД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB