2016-03-16 107 views
1

如何在此聲明中只返回1條記錄?僅在codeigniter上返回單個記錄

public function edititem($id){ 
    $this->db->select('*'); 
    $query = $this->db->get('tblitem'); 
    $this->db->where('item_id',$id); 

    foreach ($query->result() as $row){ 
     echo $row->item_id.'</br>'; 
     echo $row->item_name.'</br>'; 
     echo $row->item_description.'</br>'; 
     echo $row->item_price.'</br>'; 
    } 
} 

它給我的所有記錄,而不是

+0

只需添加'$ this-> db-> select('column_name');'並使用' - > row()'獲取單個記錄 – Saty

+0

您將返回哪個單值? – Saty

+0

我的意思是單個記錄不是單個值。我想要使​​用其編號的商品的名稱,說明和價格 – aronccs

回答

0

使用$this->db->limit(1);只得到1分的紀錄。

+1

正是我需要的,謝謝! – aronccs

0

使用這些

方法01 - $this->db->get()

$query = $this->db->get('tblitem' ,1 , 0); # Set Limit 

方法02 - $this->db->limit() in CI

$this->db->limit(1); 

方法03 - Result Rows in CI

$row = $query->first_row('array'); 
$row = $query->last_row('array'); 
$row = $query->next_row('array'); 
$row = $query->previous_row('array'); 

這些只會產生一組數據。並在foreach循環後總是回到一個

1

有關讀取單行形式表使用->row()

function edititem($id) { 
    $this->db->select('item_id,item_name, item_description,item_price'); 
    $this->db->where('item_id', $id); 
    $this->db->limit(1);// only apply if you have more than same id in your table othre wise comment this line 
    $query = $this->db->get('tblitem'); 
    $row = $query->row(); 

    echo $row->item_id . '</br>'; 
    echo $row->item_name . '</br>'; 
    echo $row->item_description . '</br>'; 
    echo $row->item_price . '</br>'; 
} 

https://www.codeigniter.com/userguide3/database/results.html

0

使用limit,因此SQL將返回只有第一行發現,但不是整組的行。關於獲得結果的CI's manual is explicit

我這裏還有兩個一班輪解決方案,通過get()

// ... other query conditions 
$this->db->limit(1)->get('tblitem')->row()->your_key; 

// or with the short syntax for defining limit, through the get: 
$this->db->get('tblitem', 1, 0)->row()->your_key; 
如果您稍後需要參考的幾個值,分配行()變量的結果

,以後再使用。

$row = $this->db->limit(1)->get('tblitem')->row(); 
0
使用

此:

$this->db->get()->custom_row_object(0, 'Your_Model'); 

上面的代碼是由笨用戶指南中提到的。最好的方面是無需循環foreach,您可以獲得非常具體的行值。

相關問題