Как после INSERT’а в таблицу с полем auto_increment получить значение этого поля?
Опубликовано 16 Декабрь 2007 в: Новости хостинга
Comments Off
В MySQL есть встроенные средства для получения этих данных. Многие языки программирования умеют с этими средствами работать.
Например, в PHP есть функция mysql_insert_id(). Она возвращает значение поля auto_increment после последнего INSERT'а в том соединении, на который ссылается переданный функции указатель. Если никакие параметры не указаны, используется последнее открытое соединение.
В Perl'е аналогичная функциональность есть в модуле DBD::mysql:
$insertid = $dbh->{'mysql_insertid'};
© Хостинг "Зенон Н.С.П.", "Как после INSERT'а в таблицу с полем auto_increment получить значение этого поля?"
Как в MySQL при наличии некоторых данных изменить их, а при отсутствии - добавить?
Опубликовано 16 Декабрь 2007 в: Новости хостинга
Comments Off
Конструкция получается достаточно трудоемкая.
В некоторых случаях бывает эффективнее использовать команду MySQL REPLACE. По синтаксису она эквивалентна INSERT.
Логика работы REPLACE такова: если в существующей строке есть поле, для которого построен индекс типа PRIMARY KEY или UNIQUE, с тем же значением, что и в новой строке, то старая строка удаляется, а новая - добавляется. Если строки с таким значением в указанном поле нет, то строка просто добавляется.
© Хостинг "Зенон Н.С.П.", "Как в MySQL при наличии некоторых данных изменить их, а при отсутствии - добавить?"