5

odbc 接続データベースから mysql データベースにテーブルをインポートする mysqli 準備済みステートメントを作成しようとしています。106 列幅のテーブル クエリでこのエラーが発生します。

SQL 構文にエラーがあります。near '? を使用する正しい構文については、MySQL サーバーのバージョンに対応するマニュアルを確認してください。(ID, column1, column2, column3, column4, ' at line 1"

ここでクエリをエコーアウトすると...

に挿入しますか? (ID, column1, column2, column3, column4, ...合計 106 列...) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ? 、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、? 、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、? 、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、? 、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?、?)

$sql = "SELECT * FROM $table WHERE $key = '$acct'";
$link = getODBCConnection();
$result = odbc_do($link, $sql);
$data = array();
while ($row = odbc_fetch_array($result)) { 
        //store all query rows as array
        array_push($data, $row);
}   
//insert into mysql table of the same name
//get column count from first row
$columns = count($data[0]);
$params = str_repeat(" ?,",$columns);
$params = rtrim($params,',');
$types = str_repeat("s",$columns+1);
$fields = implode(", ", array_keys($data[0]));
$sql = "INSERT INTO ? ($fields) VALUES ($params) ON DUPLICATE KEY UPDATE";
echo $sql."<br>";
$link = getSalesConnection();
$stmt = $link->prepare($sql);
var_dump($link->error);
foreach ($data as $row) {
        $stmt->bind_param($types, $table, implode(", ",array_values($row)));
        $stmt->execute();
}  

標準の bind_param と call_user_func_array() メソッドを使用してこれを試しました。パラメータ文字列と列名を引用しようとしましたが、効果はありませんでした。bind_param 型でエラーが発生した場合、prepare ステートメントでエラーが発生するべきではありませんか? しかし、prepare コマンドに送られる SQL には特定できない問題があります。助けてください!

4

2 に答える 2

2

bind_param() 関数が最初の「?」を置き換えていないように見えます。テーブル名を定義します。最初に準備された文字列にテーブル名を手動で入力してみて、「?」のみを使用してください。値が期待されるマーカー。

于 2013-07-10T22:32:21.850 に答える