2

重複の可能性:
mysql_query で更新すると null が返される場合がある

PHPコードで使用updateしています。mysql_querylocalhost (xampp) では私のコードは正しく動作しますが、本番ホストではコードが正しく動作することがよくありますが、更新クエリの結果が返されないことがあります。

更新が失敗した場合、'error' または '0' を返す必要がありますが、結果は返されません。なんで?

これは私のコードです:

<?php
.
.
.
$QUERY_TRANSACTION = mysql_query('START TRANSACTION');
if(!$QUERY_TRANSACTION){
    echo "error 101" ;
    exit;
}
$seed_query = "INSERT INTO seeds VALUES('','$username','$theTime','در انتظار')";
$seed_result = mysql_query($seed_query);
if(mysql_affected_rows()!=1){
    $QUERY_TROLLBACK = mysql_query('ROLLBACK');
    echo "error 102";       
    exit;       
}
$seed_id = mysql_insert_id();                           
$_SESSION['SEED_ID'] = $seed_id;

$query_values = "(NULL,'$list_number[0]',0,$seed_id)";                  
for($i=1;$i<count($list_number);$i++){
    $query_values .= ",(NULL,'$list_number[$i]',0,$seed_id)";
}               
$r_query = "INSERT INTO rc_members VALUES $query_values";
$r_result = mysql_query($r_query);
if(mysql_affected_rows()<=0){
    $QUERY_TROLLBACK = mysql_query('ROLLBACK'); 
    echo "error 103";       
    exit;       
}
$QUERY_COMMIT = mysql_query('COMMIT');
//--------------
$QUERY_TRANSACTION = mysql_query('START TRANSACTION');
if(!$QUERY_TRANSACTION){
    echo "error 104" ;
    exit;
}
$s_status = the_process($list_number,$m,$seed_id);                                          
if($s_status == 'successful_proc'){
    $s_query = "UPDATE seeds SET status='انجام شده' WHERE id=$seed_id";                                                     
    $s_result = mysql_query($s_query);
    //----------------logg file
    $filename = "debug.txt" ;
    $filepointer =fopen($filename ,"w") ;
    fwrite($filepointer , print_r($s_result,true)) ;
    fclose($filepointer) ;              
    //-----------------------
    if(!$s_result){
        echo "error 105".$s_result;                 
        exit;
    }
    $QUERY_COMMIT = mysql_query('COMMIT');
    echo 'successfuly process';
}else{
    $QUERY_TROLLBACK = mysql_query('ROLLBACK');
    echo 'error 106';
    exit;
}
$QUERY_COMMIT = mysql_query('COMMIT');  

?>

常に「正常に処理されました」が出力されますが、$s_result の値なしで「エラー 105」が出力されることがあります。$s_result をファイルに保存しようとすると、ファイルに保存されていない結果が表示されます。つまり、$s_result は null です。ありがとう

4

1 に答える 1

0

レコードが影響を受けていないかエラーの場合、MySql が false を返す問題

の代わりに、クエリの後に mysql_affected_rows() を使用できます。

if(!$s_result){
        echo "error 105".$s_result;                 
        exit;
}

あなたが使用することができます

if(mysql_affected_rows($s_result) == -1){
        echo "error 105".$s_result;                 
        exit;
}

関数のマニュアルへのリンク: mysql_affected_rows

于 2013-01-03T10:31:43.043 に答える