ошибка базы данных: A PHP Ошибка в codeigniter 3 - PullRequest
0 голосов
/ 19 февраля 2020

Моя модель:

class Admin_model extends CI_Model{
    function add_blog($data){
        $this->db->insert('blog',$data);
        return true;
    }
}

Моя функция контроллера:

function add_blog(){

    $this->form_validation->set_rules('heading','Heading', 'trim|required');
    if ($this->form_validation->run() == FALSE) {
        $this->session->set_flashdata('error',"Please check the required field");
        redirect('admin/dashboard/add');
    }else{
        //for upload file
        $config['upload_path'] = './assets/uploads/';
        $config['allowed_types'] = 'pdf|doc|docx|txt|jpeg|png|ppt';
        $this->load->library('upload', $config);

        if ( ! $this->upload->do_upload())
        {
            $error = array('error' => $this->upload->display_errors());
        }
        else
        {
            $image_path = base_url("uploads/".$post['raw_name'].$post['file_ext']);
            $data['picture']  = $image_path;
            $data_image = array('upload_data' => $this->upload->data());
        }
        //Upload file end
        $data['picture'] = $data_image['upload_data']['file_name']; 
        $data['heading'] = ucwords($this->input->post('heading'));
        $data['description'] = ucfirst($this->input->post('description'));
        $data['type_id'] = ucwords($this->input->post('type_id'));
        $data['price'] = $this->input->post('price');

        $insert_data = $this->admin_model->add_blog($data);
        if($insert_data){
            echo '<script>alert("Note added sucessfully.");</script>';
            redirect('admin/dashboard');
        }else{
            $this->session->set_flashdata('message',"There is problem in inserting data, please retry once");
            echo "error at last ";
            redirect('admin/dashboard/add');
        }
    }
}

Мой взгляд:

<form role="form" name="myForm"  method="post" enctype="multipart/form-data" action="<?php echo site_url('admin/dashboard/add_blog');?>">
    <label for="">Category</label>
    <select name="type_id" id="" class="form-control" >
        <?php
            if(count($product_list )>0 ){
                foreach ($product_list as $key => $value) {
                ?>
                <option value="<?php echo $value['type_id'];?>"><?php echo $value['type'];?></option>
                <?php
                }}?>
    </select>

    <label for=""> Heading </label>
    <input type="text" name="heading"class="form-control">
    <label for="">Price</label>
    <input type="number" name="price" class="form-control">
    <label for="">Description</label>
    <textarea name="description" id="" cols="30" rows="5" class="form-control"></textarea>
</div>

<div class="form-group">
    <label for="exampleInputFile">Upload pic</label>
    <div class="input-group">
        <div class="custom-file">
            <!--  <input type="file" name="userfile" class="form-control"> -->
            <?php echo form_upload(['name'=>'userfile']); ?>
        </div>
    </div>
    <?php if(isset($upload_error)){echo $upload_error;}?>
</div>
</div>
<div class="card-footer">
    <button type="submit" class="btn btn-primary">Submit</button>
</div>
</form>
</div>

A PHP Произошла ошибка

Важность: Уведомление Сообщение: неопределенная переменная: data_image Имя файла: admin / Dashboard. php Номер строки: 64

Backtrace:

Файл: /opt/lampp/htdocs/shremad/application/controllers/admin/Dashboard.php Строка: 64 Функция: _error_handler

Файл: /opt/lampp/htdocs/shremad/index.php Строка: 315 Функция: require_once

A PHP Произошла ошибка

Уровень важности: Уведомление Сообщение: Попытка получить доступ к смещению массива по значению типа null Имя файла: admin / Dashboard. php Номер строки: 64

Backtrace:

Файл: /opt/lampp/htdocs/shremad/application/controllers/admin/Dashboard.php Line : 64 Функция: _error_handler

Файл: /opt/lampp/htdocs/shremad/index.php Строка: 315 Функция: require_once

Ошибка базы данных Oc curred

Номер ошибки: 1048 Колонка 'picture' не может быть нулевой

INSERT INTO blog (picture, heading, description, type_id, price) VALUES (NULL, 'Djjdjdj', 'Jjdjdj', '1', '')

Имя файла: models / Admin_model. php Номер строки: 5

1 Ответ

1 голос
/ 19 февраля 2020

Давайте сначала проанализируем сообщение об ошибке.

Сообщение: неопределенная переменная: data_image

Что означает, что где-то в коде вы вызов переменной с именем «data_image», которая не определена. Теперь, пожалуйста, обратите внимание, что это УВЕДОМЛЕНИЕ, поэтому могут быть случаи, когда ваш код будет работать хорошо, НО это плохая практика и может вызвать проблемы. (Как, например, в вашем случае).

Глядя на ваш код, следующий «блок»:

    if ( ! $this->upload->do_upload())
    {
        $error = array('error' => $this->upload->display_errors());
    }
    else
    {
        $image_path = base_url("uploads/".$post['raw_name'].$post['file_ext']);
        $data['picture']  = $image_path;
        $data_image = array('upload_data' => $this->upload->data());
    }
        //Upload file end
    $data['picture'] = $data_image['upload_data']['file_name']; 

Переменная $data_image определяется только под «else» заявление. Поэтому, если условие возвращает true, переменная $data_image действительно не определена. В этом случае следующая команда:

$data['picture'] = $data_image['upload_data']['file_name']; 

, основанная на переменной $data_image, выдаст еще одну проблему:

Сообщение: попытка получить доступ к смещению массива по значению типа null

, поэтому $data['picture'] сейчас равно NULL, что вызывает вашу последнюю проблему:

Столбец 'picture' не может быть пустым

Решение?

Убедитесь, что у вас есть значение для $ data_image, даже если условие возвращает true. Или, если это условие возвращает истину - обрабатывать вещи по-другому. Также обратите внимание, что может быть логическая проблема с функцией в условии, которое возвращает неожиданный результат.

(Условие: if ( ! $this->upload->do_upload()))

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