Как определить в MYSQL ID для вставки?

программирование базы данных

Такая таблица (table1)
ID NUM Q A
Мне надо вставить что-то такое
INSERT INTO `table1` (num, q, a) VALUES ((SELECT MAX(`num`) FROM `table1` WHERE `q`=1), '2','6')

Но естественно ошибка будет.
Проблема заключается в том, что есть риск того, что при делании такого запроса (PHP)

$r = mysql_query("SELECT MAX(num) FROM table1 WHERE q='a'");
$f = mysql_fetch_array($r);
$lastnum = (int) $f[0];
$nextnum = $lastnum + 1;
$r = mysql_query("INSERT INTO `table1` (num, q, a) VALUES ($nextnum, 'aa', 'bb')");

так вот проблема заключается в том, что если 2 скрипта PHP будут работать то, $nextid может быть уже занят, т.к. 1-ый скрипт сработал быстрее....

Что же делать?
Ответы:
использовать конструкцию insert ... select, вместо  values
mysql_query('LOCK TABLES `table1` WRITE');
$r = mysql_query("SELECT MAX(num) FROM table1 WHERE q='a'");
$f = mysql_fetch_array($r);
$lastnum = (int) $f[0];
$nextnum = $lastnum + 1;
$r = mysql_query("INSERT INTO `table1` (num, q, a) VALUES ($nextnum, 'aa', 'bb')");
mysql_query('UNLOCK TABLES');
не проще у поля автоинкремент поставить?


14 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.