इस के साथ आधे दिन के बाद, पता चला कि पीडीओ एक बग था जहां ...
-
//This would run as expected:
$pdo->exec("valid-stmt1; valid-stmt2;");
-
//This would error out, as expected:
$pdo->exec("non-sense; valid-stmt1;");
-
//Here is the bug:
$pdo->exec("valid-stmt1; non-sense; valid-stmt3;");
यह निष्पादित "valid-stmt1;"
, पर रोक "non-sense;"
और एक त्रुटि कभी नहीं फेंकेंगे। नहीं चलेगा "valid-stmt3;"
, सच लौटाओ और झूठ बोलो कि सब कुछ अच्छा हुआ।
मैं यह उम्मीद करूंगा कि इसमें त्रुटि होगी "non-sense;"
लेकिन ऐसा नहीं है।
यहां मुझे यह जानकारी मिली है:
अमान्य PDO क्वेरी त्रुटि नहीं देती है
यहाँ बग:
https://bugs.php.net/bug.php?id=61613 है
इसलिए, मैंने mysqli के साथ ऐसा करने की कोशिश की और वास्तव में कोई ठोस जवाब नहीं मिला कि यह कैसे काम करता है इसलिए मैंने सोचा कि मैं इसे सिर्फ उन लोगों के लिए यहां छोड़ता हूं जो इसका उपयोग करना चाहते हैं।
try{
// db connection
$mysqli = new mysqli("host", "user" , "password", "database");
if($mysqli->connect_errno){
throw new Exception("Connection Failed: [".$mysqli->connect_errno. "] : ".$mysqli->connect_error );
exit();
}
// read file.
// This file has multiple sql statements.
$file_sql = file_get_contents("filename.sql");
if($file_sql == "null" || empty($file_sql) || strlen($file_sql) <= 0){
throw new Exception("File is empty. I wont run it..");
}
//run the sql file contents through the mysqli's multi_query function.
// here is where it gets complicated...
// if the first query has errors, here is where you get it.
$sqlFileResult = $mysqli->multi_query($file_sql);
// this returns false only if there are errros on first sql statement, it doesn't care about the rest of the sql statements.
$sqlCount = 1;
if( $sqlFileResult == false ){
throw new Exception("File: '".$fullpath."' , Query#[".$sqlCount."], [".$mysqli->errno."]: '".$mysqli->error."' }");
}
// so handle the errors on the subsequent statements like this.
// while I have more results. This will start from the second sql statement. The first statement errors are thrown above on the $mysqli->multi_query("SQL"); line
while($mysqli->more_results()){
$sqlCount++;
// load the next result set into mysqli's active buffer. if this fails the $mysqli->error, $mysqli->errno will have appropriate error info.
if($mysqli->next_result() == false){
throw new Exception("File: '".$fullpath."' , Query#[".$sqlCount."], Error No: [".$mysqli->errno."]: '".$mysqli->error."' }");
}
}
}
catch(Exception $e){
echo $e->getMessage(). " <pre>".$e->getTraceAsString()."</pre>";
}