Zasadniczo to, czego szukasz, może być tym INSERT ... ON DUPLICATE KEY UPDATE
- pod warunkiem, że używasz MySQL, a Twoje id jest unikalnym kluczem w tabeli.
Musisz ręcznie skonstruować zapytanie i przekazać do $this->db->query()
zamiast jakichkolwiek wbudowanych aktywnych rekordów, takich jak funkcje pomocnicze sterownika DB.
Przykład:
$sql = 'INSERT INTO menu_sub (id, name, desc, misc)
VALUES (?, ?, ?, ?)
ON DUPLICATE KEY UPDATE
name=VALUES(name),
desc=VALUES(desc),
misc=VALUES(misc)';
$query = $this->db->query($sql, array( $id,
$this->validation->name,
$this->validation->desc,
$this->validation->misc
));