2011-02-18 84 views
0

我正在运行一些代码&我没有得到任何错误,但行也没有被删除....所以我有点困惑。所以我检查了代码&发现我的查询有问题,但同时它不会产生真正的结果给我的mysql_error()测试。为什么这个查询不产生mysql_error()结果?

我使用下面的代码..

 try { 
      // Start transaction 
      beginTransaction($this->db_connection); 
     } catch (Exception $e) { 
      throw new Exception($e->getMessage()); 
     } 

     try { 

      // Delete main entry 
      $this->removeMainEntry($lid); 

      // Delete list columns 
      $this->removeListColumns($lid); 

      // Commit changes to database 
      commitChanges($this->db_connection); 

     } catch (Exception $e) { 

      try { 
       // Rollback changes 
       rollback($this->db_connection, $e->getMessage()); 
      } catch (Exception $re) { 
       throw new Exception($re->getMessage()); 
      } 

      throw new Exception($e->getMessage());      

     } 

这里是哪里出了问题&它不进入mysql_error()部分..

protected function removeMainEntry($lid) { 

    $lid = (int) $lid; 

    // Remove from database 
    $query = "DELET FROM lists WHERE id=" . $lid . " LIMIT 1"; 
    $sql = mysql_query($query, $this->db_connection); 

    if (mysql_error()) { 
     $etext = 'Problem removing list main entry from database.'; 
     $log_error = $etext . ' MySQL Error: ' . mysql_error() . '. Query: ' . $query; 
     log_site_error($log_error); 
     throw new Exception($etext); 
    } 

} 

下面是从代码我使用的那些函数..

if (!function_exists('beginTransaction')) { 

    function beginTransaction($dblink) { 

     $query = "BEGIN"; 
     mysql_query($query, $dblink); 

     if (mysql_error()) { 
      $etext = 'Problem adding new list data to database.'; 
      $log_error = $etext . ' MySQL Error: ' . mysql_error() . '. Query: ' . $query; 
      log_site_error($log_error); 
      throw new Exception($etext);    
     } 

    } 

} 

if (!function_exists('commitChanges')) { 

    function commitChanges($dblink) { 

     $query = "COMMIT"; 
     mysql_query($query, $dblink); 

     if (mysql_error()) { 
      $etext = 'Problem adding new list data to database.'; 
      $log_error = $etext . ' MySQL Error: ' . mysql_error() . '. Query: ' . $query; 
      log_site_error($log_error); 
      throw new Exception($etext);    
     } 

    }  

} 

if (!function_exists('rollback')) { 

    function rollback($dblink, $error = '') { 

     $query = "ROLLBACK"; 
     mysql_query($query, $dblink); 

     if (mysql_error()) { 
      $etext = $error . ' Additionally there was a problem rolling back the changes in the database. Please check the logs.'; 
      $log_error = $etext . ' MySQL Error: ' . mysql_error() . '. Query: ' . $query; 
      log_site_error($log_error); 
      throw new Exception($etext); 
     } 

    } 

} 
+0

什么问题?你能提供实际的错误信息吗?当您在mysql控制台中直接尝试查询时会发生什么? – eykanal 2011-02-18 17:28:41

+0

你可以试试`mysql_error($ dblink)`吗? – 2011-02-18 17:28:52

回答

3

如果您删除0行,它可能仍然会被视为一个成功。使用mysql_affected_rows确保你确实做了任何事情。

相关问题