首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Postgresql:"user“或其附近的语法错误

Postgresql:"user“或其附近的语法错误
EN

Stack Overflow用户
提问于 2017-07-28 17:53:36
回答 1查看 16.9K关注 0票数 10

这可能是一个简单的问题,但我花了大量令人尴尬的时间试图找出哪里出了问题。

我正在尝试对包含两列username和id的表"user“运行查询。

代码语言:javascript
运行
复制
INSERT INTO user
   (username, id) 
VALUES
   ("user", 2)

我最终得到了这个错误。

代码语言:javascript
运行
复制
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

下面是表的创建,以供参考

代码语言:javascript
运行
复制
-- 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;
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-07-28 17:56:29

在Postgres中,user是一个保留的SQL关键字。您应该避免使用保留关键字命名您的表。作为一种解决方法,您可以在引用表名时将表名放在双引号中:

代码语言:javascript
运行
复制
INSERT INTO "user"
   (username, id) 
VALUES
   ('user', 2)

我还改用单引号表示字符串文字。这有助于区分双引号和单引号的使用。

票数 24
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45370321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档