2 запроса в 1 модели (CodeIgniter)

Как я могу поместить 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();

return заставляет вашу функцию выйти до того, как она перейдет ко второму оператору. Не возвращайтесь, пока не завершите все задачи (кстати, обычно считается плохой практикой иметь одну функцию, выполняющую две вещи, по причинам, которые слишком сложны, чтобы описать их в коротком комментарии)

GordonM 20.07.2018 10:55

Спасибо за совет. Я не знаю, что делать, потому что у него есть функциональная кнопка, которая будет вставлять и обновлять разные таблицы

Yettt 20.07.2018 11:15

Пожалуйста, всегда отвечайте на ответы, давая несколько комментариев или, если это вам поможет, пометив его как зеленый и проголосовав, это лучший способ поблагодарить всех программистов.

Pradeep 20.07.2018 19:16
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
3
40
2

Ответы 2

Попробуйте внести некоторые изменения, как показано ниже:

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 и подтвердить, что данные есть.

Sinto 20.07.2018 12:02

Надеюсь, что это поможет вам :

Ваш запрос должен быть таким, и вы должны использовать транзакции с базами данных, которые поддерживают безопасные для транзакций типы таблиц.

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

Другие вопросы по теме