2013-09-30 70 views
0

我的else语句没有在执行时得到执行。代码中没有错误。它只是与我的查询和foreach语句的流程有关,但我似乎无法弄清楚这一点。有任何想法吗?PHP else语句没有执行

$id = $this->input->post('id'); 
$session_id = $this->input->post('session_id'); 
$q1 = $this->db->query("SELECT * 
    FROM default_cart 
    WHERE cookie_id = '$session_id' 
    AND product_id = '$id' LIMIT 1"); 

foreach($q1->result() as $row) { 
    if($row->cookie_id != $session_id && $row->product_id != $id) { 
     echo json_encode(array('error_code' => 'e100')); 
    } else { 
     $data = array('product_id' => $id, 
      'active' => 'Yes', 
      'cookie_id' => $session_id 
     ); 
     $this->db->insert('default_cart', $data); 
     echo json_encode(array('success' => true)); 
    } 
} 
+0

您需要测试/输出您正在查询的变量以及从查询中获得的结果,以找出与您设置的条件不匹配的原因。 – Lapidouce

+1

你的循环很奇怪。您只显式查询匹配'cookie_id = $ session_id'和'product_id = $ id'的数据集,但您希望数据库返回其他内容,所以您看到需要再次检查if。为什么? – Sven

回答

3

首先,我想表明,没有通过查询循环的感觉,当只有一个记录LIMIT 1没有,如果检查的意义,而你已经检查的所有参数查询WHERE cookie_id = '$session_id' AND product_id = '$id'只是获取查询返回的行并检查是否为空。

$id = $this->input->post('id'); 
    $session_id = $this->input->post('session_id'); 
    $q1 = $this->db->query("SELECT * FROM default_cart 
    WHERE cookie_id = '$session_id' AND product_id = '$id' LIMIT 1"); 
    $row=$q1->row(); 
    if(!empty($row)) {   
      $data = array('product_id' => $id, 
          'active' => 'Yes', 
          'cookie_id' => $session_id); 
      $this->db->insert('default_cart', $data); 
      echo json_encode(array('success' => true)); 

    }else{ 
    echo json_encode(array('error_code' => 'e100')); 
    }