Простая операция CRUD в Codeigniter?

Я выполняю простую операцию CRUD в Codeigniter.

Это мой контроллер:

public function areaEdit($area_id)
    {
        $this->global['pageTitle'] = 'Area Edit';
        $data['areaEdit'] = $this->um->areaEdit($area_id);
        $this->loadViews("utilities/area/areaEdit", $this->global, $data , NULL);
    }

    public function updateArea($area_id='area_id')
    {
        $area_name = $this->input->post('area_name');
        $area_abbr = $this->input->post('area_abbr');

        $this->form_validation->set_rules('area_name', 'Area Name', 'trim|required');
        $this->form_validation->set_rules('area_abbr', 'Area Abbrevation', 'trim');

        if ($this->form_validation->run() == FALSE) {
            $this->areaEdit($area_id);
        } else {
            $area_name = ucwords(ucfirst($this->security->xss_clean($area_name)));
            $area_abbr = ucwords(ucfirst($this->security->xss_clean($area_abbr)));

            $data = array('area_name' => $area_name, 'area_abbr' => $area_abbr);

            $result = $this->um->updateArea($data, $area_id);

            if ($result) {
                $this->session->set_flashdata('success', '<b>'.$area_name.'</b> updated successfully on '.date('d/m/Y H:i:s'));
            } else {
                $this->session->set_flashdata('error', 'Something wrong! Please try again.');
            }
            redirect(base_url('utilities/areaList'));
        }
    }

    public function deleteArea($area_id='area_id')
    {
        $result = $this->um->deleteArea($data, $area_id);

        if ($result) {
            $this->session->set_flashdata('success', '<b>'.$area_name.'</b> deleted successfully on '.date('d/m/Y H:i:s'));
        } else {
            $this->session->set_flashdata('error', 'Something wrong! Please try again.');
        }
        redirect(base_url('utilities/areaList'));
    }

А это моя модель:

public function areaEdit($area_id)
    {
        $this->db->select("*");
        $this->db->from("tbl_area");
        $this->db->where("area_id", $area_id);
        $query = $this->db->get();
        return $query->row();
    }

    public function updateArea($data, $area_id)
    {
        $this->db->where("$area_id", $area_id);
        $this->db->update("tbl_area", $data);
        if ($this->db->affected_rows() > 0) {
            return true;
        } else {
            return false;
        }
    }

    public function deleteArea($area_id='area_id')
    {
        $this->db->where("area_id", $area_id);
        $this->db->delete("tbl_area");
        if ($this->db->affected_rows() > 0) {
            return true;
        } else {
            return false;
        }
    }

Когда я запускаю этот сценарий, он выдает ошибку, он переходит в состояние else в контроллере для функции обновления и функции удаления.

Я не понимаю, где ошибаюсь?

Любая помощь приветствуется, заранее спасибо.

заменить $this->db->where("$area_id", $area_id); на $this->db->where("area_id", $area_id); в методе updateArea()

Pradeep 15.06.2018 20:25

я думаю, что $area_id должен иметь какое-то целочисленное значение вместо строки area_id

Pradeep 15.06.2018 20:32
Стоит ли изучать 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 и хотите разрабатывать...
0
2
312
1

Ответы 1

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

Аргументы несоответствия: вы передаете два параметра от контроллера, но в модели deleteArea() есть только один аргумент;

Должно быть так:

public function deleteArea($area_id='area_id')
{
   $result = $this->um->deleteArea($area_id);

   if ($result) {
      $this->session->set_flashdata('success', '<b>'.$area_name.'</b> deleted successfully on '.date('d/m/Y H:i:s'));
   } else {
      $this->session->set_flashdata('error', 'Something wrong! Please try again.');
   }
   redirect(base_url('utilities/areaList'));
 }

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