Как я могу поместить 2 запроса в 1 модель? Вот мой код
public function declineDec($email,$desc,$prop_id,$fk_table){
$sql = "INSERT INTO amilyar_applicant_notif (email,notif_fk_table,notif_fk_id,notif_content) VALUES (?,?,?,?)";
$data = [$email,$fk_table,$prop_id,$desc];
$query = $this->db->query($sql,$data);
return $this->db->affected_rows();
$sql2 = "UPDATE amilyar_properties SET prop_approved = 3 WHERE prop_id = ?";
$data2 = ($prop_id);
$this->db->query($sql2, $data2);
// return $sql;
return $this->db->affected_rows();
Спасибо за совет. Я не знаю, что делать, потому что у него есть функциональная кнопка, которая будет вставлять и обновлять разные таблицы
Пожалуйста, всегда отвечайте на ответы, давая несколько комментариев или, если это вам поможет, пометив его как зеленый и проголосовав, это лучший способ поблагодарить всех программистов.






Попробуйте внести некоторые изменения, как показано ниже:
public function declineDec($email,$desc,$prop_id,$fk_table) {
$sql = "INSERT INTO amilyar_applicant_notif (email,notif_fk_table,notif_fk_id,notif_content) VALUES (?,?,?,?)";
$data = [$email,$fk_table,$prop_id,$desc];
$this->db->query($sql,$data);
$return['insert'] = $this->db->affected_rows();
$sql2 = "UPDATE amilyar_properties SET prop_approved = 3 WHERE prop_id = ?";
$data2 = ($prop_id);
$this->db->query($sql2, $data2);
$return['update'] = $this->db->affected_rows();
return $return;
}
Нет необходимости в return в return $this->db->affected_rows();, если вам нужно выполнить больше шагов кода.
Можете ли вы сделать print_r($return); перед выпиской return и подтвердить, что данные есть.
Надеюсь, что это поможет вам :
Ваш запрос должен быть таким, и вы должны использовать транзакции с базами данных, которые поддерживают безопасные для транзакций типы таблиц.
public function declineDec($email,$desc,$prop_id,$fk_table)
{
$sql = "INSERT INTO amilyar_applicant_notif (email,notif_fk_table,notif_fk_id,notif_content) VALUES (?,?,?,?)";
$data = [$email,$fk_table,$prop_id,$desc];
$sql2 = "UPDATE amilyar_properties SET prop_approved = 3 WHERE prop_id = ?";
$data2 = array($prop_id);
$this->db->trans_start();
$this->db->query($sql,$data);
$this->db->query($sql2, $data2);
$this->db->trans_complete();
if ($this->db->trans_status())
{
return TRUE;
}
else
{
return FALSE;
}
}
Подробнее: https://www.codeigniter.com/user_guide/database/transactions.html
returnзаставляет вашу функцию выйти до того, как она перейдет ко второму оператору. Не возвращайтесь, пока не завершите все задачи (кстати, обычно считается плохой практикой иметь одну функцию, выполняющую две вещи, по причинам, которые слишком сложны, чтобы описать их в коротком комментарии)