簡體   English   中英

使用Codeigniter更新DB表中的字段狀態

[英]updating a field status in DB table using Codeigniter

我想將“尚未”狀態更新為“已經”

有錯誤

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 ?');"])?>

Codeigniter Set語法應該是

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

注意:Equal =是賦值運算符。 要比較你需要使用==比較運算符

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

UPDATE1:

您需要使用這樣的選擇查詢檢查以前的值,然后您需要根據以前的值更新狀態。

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);
}

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

應該是這樣的

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

還有一個問題

//您使用了賦值運算符而不是比較運算符

if ($status_verifikasi ='belum') {

應該

if ($status_verifikasi == 'belum') {

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM