Как обновить запись в codeigniter? - PullRequest
0 голосов
/ 18 февраля 2019

код контроллера

if($this->input->post('update'))
         {
             $n=$this->input->post('pps_pin');
             $e=$this->input->post('pps_address');
             $m=$this->input->post('stm_shipping_type');
             $a=$this->input->post('tsm_time_slot');
             $b=$this->input->post('pps_price');
             $id=$this->input->post('pps_slid');
         $this->Config_model->updaterecords($n,$e,$m,$id,$a,$b);
         redirect('Admin_ctrl/config/view_pincode_price');
         }
    }

код модели

function updaterecords($n,$e,$m,$id,$a,$b)
    {   
        $id;

        $qr=$this->db->query("UPDATE pincode_price_setup,shipping_type_mst,time_slot_mst SET pps_pin='$n',pps_address='$e',stm_shipping_type='$m',tsm_time_slot='$a',pps_price='$b' WHERE pps_slid='$id'");
        return $qr;
    }

Данные о способе доставки и времени доставки совпадают

введитеописание изображения здесь

введите описание изображения здесь

введите описание изображения здесь

Ответы [ 5 ]

0 голосов
/ 21 февраля 2019

После загрузки модели codeigniter ее функция по умолчанию update работает

if($this->input->post('update'))
     {
        $data = [
                'pps_pin' => $this->input->post('pps_pin'),
                'pps_address' => $this->input->post('pps_address'),
                'stm_shipping_type' => $this->input->post('stm_shipping_type'),
                'tsm_time_slot' => $this->input->post('tsm_time_slot'),
                'pps_price' => $this->input->post('pps_price'),
                'pps_slid' => $this->input->post('pps_slid'),
            ];
     $this->Config_model->id = $id;
     $this->Config_model->update($data);

     redirect('Admin_ctrl/config/view_pincode_price');
     }
}

Так что я уверен, что нам не нужно определять отдельную функцию в модели для той же цели.

0 голосов
/ 20 февраля 2019
 Try This code



function updaterecords($n, $e, $m, $id, $a, $b) {

             $this->db->set('pps_pin', $n);
             $this->db->set('pps_address', $e);
             $this->db->set('stm_shipping_type', $m);
             $this->db->set('tsm_time_slot', $a);
             $this->db->set('pps_price', $b);
             $this->db->where('pps_slid', $id);
             $this->db->update('pincode_price_setup');
             return ($this->db->affected_rows() != 1) ? false : true;
        }
0 голосов
/ 19 февраля 2019

Пожалуйста, попробуйте вот так

//Controller Code
function update_record($id){ 
    $update_array = array(
       'pps_pin' => $this->input->post('pps_pin') ///add fields in array which updated  
    );
    $this->modal_name->update($id,update_array);//pass id & array which want to be update
}

//Modal code

function update($id,$array){
    return $this->db->where('id',$id)->update('TABLE_NAME',array);
}
0 голосов
/ 19 февраля 2019

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

Этот код может быть не идеальным, но он работает для моего проекта localhost.

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

Пример:

public function update($id){

    $id = $this->input->post('id');

    //create $data array and add your data to array
    $data = array(
        'nazov_divizia'     =>  $this->input->post('nazov')
    );

    //send this $data array with $id to your update function in model
    $this->Divizia_model->updateData($id, $data);

    //you can create flash message if you want
    $this->session->set_flashdata('message', 'Údaje upravené');

    //redirect to your controller index function
    redirect(base_url().'divizia');
}

Создание функции для записи обновления в вашей модели.

Пример:

public function updateData($id, $data)
{
    $this->db->where('id_divizia', $id);
    $this->db->update('divizia', $data);
}
0 голосов
/ 18 февраля 2019

Вы должны изменить свой код, чтобы использовать подготовленные операторы codeigniters.Если я правильно понял отношения в вашей БД, ваш метод записи обновлений должен выглядеть примерно так:

function updaterecords($n, $e, $m, $id, $a, $b)
{
    $this->db->set('pps_pin', $n);
    $this->db->set('pps_address', $e);
    $this->db->set('stm_shipping_type', $m);
    $this->db->set('tsm_time_slot', $a);
    $this->db->set('pps_price', $b);
    $this->db->join('shipping_type_mst', 'pincode_price_setup.pps_shipping_type = shipping_type_mst.stm_sqlid');
    $this->db->join('time_slot_mst', 'pincode_price_setup.pps_time_slot = time_slot_mst.tsm_sqlid');
    $this->db->where('pps_slid', $id);
    $this->db->update('pincode_price_setup');
}

Дружественный совет: дайте вашим переменным несколько более значимых имен, было бы намного проще работать с переменной с именем $PIN-код, чем $ n.

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