>데이터 베이스 >MySQL 튜토리얼 >'order'라는 MySQL 테이블을 생성하면 SQL 구문 오류가 발생하는 이유는 무엇입니까?

'order'라는 MySQL 테이블을 생성하면 SQL 구문 오류가 발생하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-09 11:22:41206검색

Why Does Creating a MySQL Table Named

"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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.