Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Вставить запись, если такой нету за один запрос. 
V
    Опции темы
Boing747
Дата 2.5.2008, 20:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Есть таблица tab1 d MySQL. У нее есть поле ID - autoincrement и val - число.
Хотелось бы написать запрос, чтобы если нету записи с определенным значением val, то запись добавлялась, иначе нет.

Пример:
INSERT INTO tab1 (val) VALUES (1);
INSERT INTO tab1 (val) VALUES (2);
INSERT INTO tab1 (val) VALUES (1);


После такого скрипта в базе должно быть две записи(две первых, что мы добавили, а третья не добавилась, т  к уже было поле с val = 1)
Возможно ли записать за один запрос?




PM MAIL   Вверх
skyboy
Дата 2.5.2008, 20:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

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



шаг 1. создать unique key на поле val
шаг 2. воспользоваться конструкцией insert ignore .... для подавления ошибок дублирования уникального ключа
PM MAIL   Вверх
Boing747
Дата 2.5.2008, 21:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



skyboy, Спасибо, помогло. 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




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


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

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