집 >데이터 베이스 >MySQL 튜토리얼 >'order'라는 MySQL 테이블을 생성하면 SQL 구문 오류가 발생하는 이유는 무엇입니까?
"order"라는 MySQL 테이블을 생성하는 중 SQL 구문 오류가 발생했습니다.
PHP 스크립트를 사용하여 "order"라는 MySQL 테이블을 생성할 때 다음 오류가 발생할 수 있습니다. "테이블 생성 오류: SQL 구문에 'order( order_id INT UNSIGNED NOT NULL AUTO_INCREMENT, user_id ', p 근처에 오류가 있습니다. . 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!