嗯,我正在運行一個非常大的 SQL 命令。我收到錯誤 1064(語法錯誤或訪問沖突)。有沒有什么方法可以得到準備好的語句,看看錯誤可能出在哪里?我只看到 50 個字符,老實說我不知道問題是什么。這就是我創(chuàng)建和準備聲明的方式:function insertIntoMultiple($tablename, $columns, $data, $datetime_column_name = 'created_at') { global $db; $data = json_decode(base64_decode($data), true); $exp = explode(", ", $columns); $params = array_diff($exp, ["created_at"]); $real_columns = join(",", $params); // $join = join(',', json_decode($columns, true)); $query = "INSERT INTO $tablename ($real_columns, $datetime_column_name) "; $i = 0; $c = count($data); foreach ($data as $param) { $marks = getMarks($params); // $query = storeQuery("INSERT INTO $tablename ($join, $datetime_column_name) VALUES ($marks, NOW())"); $query .= "VALUES ($marks, NOW())"; $query .= $i < $c - 1 ? "," : ";"; $query .= "\n"; ++$i; } $stmt = $db->prepare($query); $pars = getParams($data, $params); $r = $stmt->execute($pars); return $r;}其中有 24 列和 1000 個值要插入。因此查詢中有 24,000 個參數(shù)。這些是我用來創(chuàng)建查詢字符串的方法:function getMarks($params, $for_update = false) { $arr = array(); foreach ($params as $param) { if($param == "created_at") continue; $arr[] = $for_update ? '$param = ?' : '?'; } return join(',', $arr);}function getParams($params, $columns) { $arr = array(); foreach ($params as $param) { foreach ($columns as $column) { if($column == "created_at") continue; $arr[] = $param[$column]; } } return $arr;}由于某種原因,這不起作用,這是我得到的獨特輸出:致命錯誤:未捕獲的 PDOException:SQLSTATE[42000]:語法錯誤或訪問沖突:1064 您的 SQL 語法有錯誤;檢查與您的 MariaDB 服務器版本相對應的手冊,了解在 'VALUES ('1','xxx','xxxx7010','','https://xxxx/xxx/5...' 附近使用的正確語法,網址為/root/project/php/api.php:126 中的第 2 行正如你所看到的,我無法讓它使用這個獨特的信息。這給了我相同的查詢(帶有標記),因為我認為這需要在給我一個異常的方法之后調用->execute(),所以我看不到任何東西。
1 回答

江戶川亂折騰
TA貢獻1851條經驗 獲得超5個贊
最好使用數(shù)據(jù)屬性在按鈕單擊時進行設置和檢索id
。下面,我向按鈕添加了一個數(shù)據(jù)屬性,并使用 jQuery 的data()來獲得id
點擊。
<input class="price" name="price" id="price_<?= $value['i_id'] ?>" value="<?= &cost ?>" />? ? ? ? ? ? ? ? ? ? ? ? ?
<input type="hidden" id="<?= $value['i_id'] ?>_suffix" value="<?= $value['suffix'] ?>" />?
<button type="button" class="sp-save btn btn-xs btn-primary btn-bell m-l-xs" id="save_<?= $value['i_id'] ?>" data-id="<?= $value['i_id'] ?>">SAVE</button>
jQuery:
id = $(this).data('id');? ? ? ?
price = $('#'+'price_'+id).val();? ? ? ? ?
s_id = $('#'+id+'_suffix').val();??
- 1 回答
- 0 關注
- 103 瀏覽
添加回答
舉報
0/150
提交
取消