这可能是一个简单的问题,但我花了很多时间试图弄清楚什么是错的.
我正在尝试对包含两列username和id的表"user"运行查询.
INSERT INTO user
(username, id)
VALUES
("user", 2)
Run Code Online (Sandbox Code Playgroud)
我最终得到了这个错误.
ERROR: syntax error at or near "user"
LINE 1: INSERT INTO user
^
********** Error **********
ERROR: syntax error at or near "user"
SQL state: 42601
Character: 13
Run Code Online (Sandbox Code Playgroud)
这是表创建供参考
-- Table: public."user"
-- DROP TABLE public."user";
CREATE TABLE public."user"
(
id integer NOT NULL,
username text COLLATE pg_catalog."default",
CONSTRAINT user_pkey PRIMARY KEY (id)
)
WITH (
OIDS = FALSE
)
TABLESPACE pg_default;
ALTER TABLE public."user"
OWNER to postgres;
Run Code Online (Sandbox Code Playgroud)
Tim*_*sen 10
在Postgres中user是一个保留的SQL关键字.您应该避免使用保留关键字命名表.作为解决方法,您可以在引用时将表名放在双引号中:
INSERT INTO "user"
(username, id)
VALUES
('user', 2)
Run Code Online (Sandbox Code Playgroud)
我也转而使用单引号作为字符串文字.这有助于区分双引号与单引号的使用.
| 归档时间: |
|
| 查看次数: |
5522 次 |
| 最近记录: |