使用Codeigniter更新DB表中的字段状态

时间:2017-06-16 08:38:20

标签: php mysql database codeigniter codeigniter-3

我想将“尚未”状态更新为“已经”

有错误

A Database Error Occurred
Error Number: 1054
Unknown column 'sudah' in 'field list'
UPDATE `tb_peserta` SET `sudah` = '' WHERE `no_pendaftaran` = '13'
Filename: C:/xampp/htdocs/codeigniter/system/database/DB_driver.php
Line Number: 691

我的控制器

function status_verifikasi($no_pendaftaran){
    $where = array('no_pendaftaran' => $no_pendaftaran);
    $this->M_pendaftar->status_verifikasi($where,'tb_peserta');
    redirect('admin/Ca_pendaftar');}

我的模特

function status_verifikasi($where,$tb_peserta){
    if ($status_verifikasi ='belum') {
       $this->db->set('sudah');
   } else{
       $this->db->set('belum');
   }
   $this->db->where($where);
   $this->db->update($tb_peserta);}

我的观点

<?=anchor('admin/Ca_pendaftar/status_verifikasi/'.$tb_peserta->no_pendaftaran,
              'Konfirmasi', ['class'=>'btn btn-success btn-sm' , 'onclick'=>"return confirm('Ubah status pendaftar ?');"])?>

2 个答案:

答案 0 :(得分:2)

Codeigniter Set语法应为

$this->db->set('column_name','value');

注意:等于=是赋值运算符。要比较您需要使用==比较运算符

if ($status_verifikasi == 'belum') { .. }

更新1:

您需要使用这样的选择查询检查以前的值,然后您需要根据以前的值更新状态。

function status_verifikasi($where,$tb_peserta){

     $this->db->select('status_verifikasi');
     $this->db->from($tb_peserta);
     $this->db->where($where);
     $result = $this->db->get()->result();

    if($result && $result[0]->status_verifikasi =='belum')
    {
       $this->db->set('status_verifikasi','sudah');
    } else{
       $this->db->set('status_verifikasi','belum');
    }

    $this->db->where($where);
    $this->db->update($tb_peserta);
}

答案 1 :(得分:1)

$this->db->set('sudah');

应该是

$this->db->set('sudah', 'value');

还有一个问题

//您使用了赋值运算符而不是比较运算符

if ($status_verifikasi ='belum') {

应该是

if ($status_verifikasi == 'belum') {