Функция обновления завершается с ошибкой «Серьезность: уведомление» - PullRequest
0 голосов
/ 28 апреля 2011

Я новичок в PHP и CodeIgniter.Я создаю приложение CRUD, которое хорошо работает, ожидают операции обновления.

Мой контроллер:

class Site extends CI_Controller {

       function __construct()
       {
            parent::__construct();
        $this->is_logged_in();
       }

    function members_area() 
    {
        $data = array();

        if($query = $this->site_model->get_records()) // site model is autoloaded.
        {
            $data['records'] = $query;
        }

        $this->load->view('members_area', $data);
    }

    function create()
    {
        $data = array(
            'title' => $this->input->post('title'),
            'content' => $this->input->post('content')
        );

        $this->site_model->add_record($data);
        $this->members_area();
    }

    function delete()
    {
        $this->site_model->delete_row();
        $this->members_area();
    }

    function update()
    {
        $data = array(
            'title' => $this->input->post('updtitle'),
            'content' => $this->input->post('updcontent')
        );

        $this->site_model->update_record($data);
        $this->members_area();
    }

    function is_logged_in()
    {
    $is_logged_in = $this->session->userdata('is_logged_in');

    if(!isset($is_logged_in) || $is_logged_in != true)
        {
                $this->load->view('login_form');
        }
    }
}

Моя модель:

class Site_model extends CI_Model {

    function get_records()
    {
        $query = $this->db->get('data');
        return $query->result();
    }

    function add_record($data) 
    {
        $this->db->insert('data', $data);
        return;
    }

    function delete_row()
    {
        $this->db->where('id', $this->uri->segment(3));
        $this->db->delete('data');
    }

    function update_record($data) 
    {
        $this->db->where('id', $id);
        $this->db->update('data', $data);
    }    

Мой взгляд:

<h2>update</h2>
    &lt;?php echo form_open('site/update');?&gt;
    <p>
        <label for="update title">Update Title:</label>
        &lt;input type="text" name="updtitle" id="updtitle" /&gt;
    </p>

    <p>
        <label for="update content">Update Content:</label>
        &lt;input type="text" name="updcontent" id="updcontent" /&gt;
    </p>    

    <p>
        &lt;input type="submit" value="Update" /&gt;
    </p>
    &lt;?php echo form_close(); ?&gt;

    <hr />

Если я пытаюсь обновить запись вмоя база данных, я получаю сообщение об ошибке в моей модели («Серьезность: Уведомление», «Сообщение: неопределенная переменная: идентификатор»), и обновление НЕ происходит.

Чего мне не хватает?Можете ли вы помочь?Спасибо.

Ответы [ 2 ]

2 голосов
/ 28 апреля 2011

Вы не определили $id в вызове модели:

function update_record($data) 
{
    $this->db->where('id', $id);// <-- $id is not defined
    $this->db->update('data', $data);
}   

Вы также не используете его в вызове контроллера:

function update()
{
    $data = array(
        'title' => $this->input->post('updtitle'),
        'content' => $this->input->post('updcontent')
    );

    $this->site_model->update_record($data);
    $this->members_area();

    // Where is id??

}
0 голосов
/ 28 апреля 2011

Я нашел решение, переделав свое приложение.

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

Теперь я полагаюсь на URI записи, которую я хочу обновить:

1) в моем контроллере, я добавил эту функцию обновления

function update() {
    $id = $this->uri->segment(3);
    $title = $this->input->post('title');
    $content = $this->input->post('content');

    $this->posts_model->update_record($id, $title, $content)
} 

2) в свою модель я добавил эту функцию

function update_record($id, $title, $content) {
    $data = array(
        'title' => $title,
        'content' => $content
    );

    $this->db->where('id', $id);
    $this->db->update('data', $data);
} 

3) наконец, я создал вид только для обновления

<?php $this->load->helper('form'); ?>

<?php echo form_open('site/update/'.$id); ?>

        <?php echo form_input('title'); ?>
        <?php echo form_textarea('content'); ?>
        <?php echo form_submit('submit', 'Submit'); ?>

<?php echo form_close(); ? 

Теперь все работает нормально,Все, что мне нужно сделать, это указать моему браузеру site / update / post-id_number .

Что мне нужно выяснить, так это настроить интерфейс, чтобы я мог объединить вид обновленияс другим у меня.

Спасибо, что нашли время.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...