Moje rozwiązanie (używając Zend) polegało na ZABLOKOWANIU tabeli, następnie zapytaniu o numer_elementu, dołączeniu wyniku do zapytania INSERT, wstawieniu i ODBLOKOWANIU tabeli. Oto jak ZABLOKOWAĆ i ODBLOKOWAĆ:
$sql = "LOCK TABLE items WRITE";
$this->getAdapter()->query($sql);
//run select to get last item_number
//append result to insert array
//insert
$sql = "UNLOCK TABLES";
$this->getAdapter()->query($sql);
Innym sposobem jest napisanie zapytania tak, aby wartość została wybrana podczas wstawiania. Oto przykład:
$sql = INSERT INTO items (item_id, item_family, item_name, item_number)
VALUES (item_id, item_family, item_name, (SELECT item_number FROM... )+1);
$this->getAdapter()->query($sql);
Więcej informacji na temat tego rodzaju zapytań w MySQL Web