第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

調(diào)試 SQL 中的錯(cuò)誤 1064,以查看長(zhǎng) SQL 語(yǔ)句的失敗原因

調(diào)試 SQL 中的錯(cuò)誤 1064,以查看長(zhǎng) SQL 語(yǔ)句的失敗原因

PHP
吃雞游戲 2023-10-15 15:39:58
嗯,我正在運(yùn)行一個(gè)非常大的 SQL 命令。我收到錯(cuò)誤 1064(語(yǔ)法錯(cuò)誤或訪問沖突)。有沒有什么方法可以得到準(zhǔn)備好的語(yǔ)句,看看錯(cuò)誤可能出在哪里?我只看到 50 個(gè)字符,老實(shí)說(shuō)我不知道問題是什么。這就是我創(chuàng)建和準(zhǔn)備聲明的方式: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 個(gè)值要插入。因此查詢中有 24,000 個(gè)參數(shù)。這些是我用來(lái)創(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;}由于某種原因,這不起作用,這是我得到的獨(dú)特輸出:致命錯(cuò)誤:未捕獲的 PDOException:SQLSTATE[42000]:語(yǔ)法錯(cuò)誤或訪問沖突:1064 您的 SQL 語(yǔ)法有錯(cuò)誤;檢查與您的 MariaDB 服務(wù)器版本相對(duì)應(yīng)的手冊(cè),了解在 'VALUES ('1','xxx','xxxx7010','','https://xxxx/xxx/5...' 附近使用的正確語(yǔ)法,網(wǎng)址為/root/project/php/api.php:126 中的第 2 行正如你所看到的,我無(wú)法讓它使用這個(gè)獨(dú)特的信息。這給了我相同的查詢(帶有標(biāo)記),因?yàn)槲艺J(rèn)為這需要在給我一個(gè)異常的方法之后調(diào)用->execute(),所以我看不到任何東西。
查看完整描述

1 回答

?
牧羊人nacy

TA貢獻(xiàn)1862條經(jīng)驗(yàn) 獲得超7個(gè)贊

代替 $query = "INSERT INTO $tablename ($real_columns, $datetime_column_name) ";

用這個(gè) $query = "INSERT INTO $tablename ($real_columns, $datetime_column_name) VALUES";

并且也替換這條線$query .= "VALUES ($marks, NOW())";

$query .= "($marks, NOW())";


查看完整回答
反對(duì) 回復(fù) 2023-10-15
  • 1 回答
  • 0 關(guān)注
  • 142 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)