2

mysql dynamic-sql ステートメントがあり、pdo を使用して実行したいのですが、次のエラー メッセージが表示されます。

警告: PDOStatement::fetchAll() [pdostatement.fetchall]: SQLSTATE[HY000]: C:\xampp\htdocs\tags\cobasql.php 行 29 の一般エラー

これが私のphpコードです:

<?php 
   $uname = 'root'; //nama username database 
   $pwd = ''; //Password database 
   $dbname = 'eav_latihan'; //nama Database 

   /* Initialisasi database */ 
   $db = new PDO('mysql:host=localhost;dbname='.$dbname, $uname, $pwd); 
   $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING); 


   $query = "SET @sql = NULL; ". 
            " SELECT GROUP_CONCAT(DISTINCT CONCAT('MAX(IF(a.Name = ''', ". 
            " a.Name, ''', ca.value, NULL)) AS ', a.Name )) INTO @sql ". 
            " FROM cust_attribute ca ". 
            " INNER JOIN attribute a ON ca.idAttribute = a.idAttribute ". 
            " INNER JOIN customer c ON c.idCustomer = ca.idCustomer ". 
            " WHERE a.publish = 'Y'; ". 
            " SET @sql = CONCAT('SELECT c.idCustomer, c.namaCustomer, ' ". 
            " ' c.email, c.noTelp, ', @sql, ' FROM cust_attribute ca', ". 
            " ' INNER JOIN attribute a ON ca.idAttribute = a.idAttribute', ". 
            " ' INNER JOIN customer c ON c.idCustomer = ca.idCustomer', ". 
            " ' GROUP BY c.idCustomer'); ". 
            " SELECT @sql; ". 
            " prepare stmt FROM @sql; ". 
            " execute stmt;"; 

   $result_array = array();
   $queryku = $db->query($query);
   $result_array = $queryku->fetchAll(PDO::FETCH_OBJ);
   echo $result_array;
?>

ここの誰かが私を助けてくれるか、提案してください??

4

1 に答える 1

-1

接続できないようです。

この行はこちら

$db = new PDO('mysql:host=localhost;dbname='.$dbname, $uname, $pwd);

$dbname 変数を削除して、正しい値を入力して、行が次のようになるようにしてください

 $db = new PDO('mysql:host=localhost;dbname=dbname', $uname, $pwd);
于 2012-11-05T03:22:26.680 に答える