建立名為「order」的MySQL表時出現SQL語法錯誤
使用PHP腳本建立名為「order」的MySQL表時,可能會遇到錯誤:「建立表格錯誤:您的SQL語法在'order( order_id INT UNSIGNED NOT NULL AUTO_INCREMENT, user_id '附近有錯誤,第1行[重複]」。此問題可能是由於SQL語句中的語法錯誤造成的。
具體來說,由於使用了保留字「order」且未正確轉義,因此會出現語法錯誤。在SQL中,必須使用反引號 (`) 將保留字轉義,以將其與表名或列名區分開來。
要解決此錯誤,您可以如下轉義「order」保留字:
<code class="language-sql">CREATE TABLE `order` ( order_id INT UNSIGNED NOT NULL AUTO_INCREMENT, user_id INT UNSIGNED NOT NULL, transaction_id VARCHAR(19) NOT NULL, payment_status VARCHAR(15) NOT NULL, payment_amount DECIMAL(6,2) UNSIGNED NOT NULL, payment_date_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (order_id), FOREIGN KEY (user_id) REFERENCES user (user_id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;</code>
透過這樣做,MySQL 將識別「order」為有效的表名,並且表將成功建立。
或者,您可以避免使用保留字,而為您的表使用不同的名稱。這有助於防止將來出現潛在的語法錯誤。
以上是為什麼建立名為「order」的 MySQL 表會導致 SQL 語法錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!