亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

創建語句返回錯誤:“RETURNING”處或附近的語法錯誤

創建語句返回錯誤:“RETURNING”處或附近的語法錯誤

冉冉說 2023-03-02 16:37:01
我想用 CREATE 語句創建一個數據庫表。我得到一個錯誤說Error: syntax error at or near "RETURNING". 我知道 JDBC 驅動程序存在某種錯誤。正如我發現的那樣。 Postgres JDBC 驅動程序:PSQLException:RETURNING 處或附近的語法錯誤看來我需要設置 Quirk 模式。但我不確定該怎么做。現在我有Connection dbConnection;dbConnection = DriverManager.getConnection(connectionString,username,password);Statement st = dbConnection.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);st.executeUpdate(query,Statement.RETURN_GENERATED_KEYS);我不知道我應該在哪里設置怪癖模式編輯:很抱歉遺漏了細節。它帶我通過了引導方式。該聲明是通過st.executeUpdate(query,Statement.RETURN_GENERATED_KEYS);SQL是        String employeeTable="CREATE TABLE \"employee\" (\n" +                 "   \"employee_id\" serial,\n" +                 "   \"employee_first_name\" TEXT,\n" +                 "   \"employee_middle_name\" TEXT,\n" +                 "   \"employee_last_name\" TEXT,\n" +                 "   \"employee_dob\" date ,\n" +                 "   \"employee_ssn\" TEXT NOT NULL DEFAULT '0',\n" +                 "   \"employee_wages\" FLOAT(30) NOT NULL DEFAULT '0',\n" +                 "   \"employee_password\" TEXT DEFAULT '0',\n" +                 "   \"employee_issupervisoer\" BOOLEAN NOT NULL DEFAULT 'false',\n" +                 "   \"employee_hassupervisoer\" BOOLEAN NOT NULL DEFAULT 'false',\n" +                 "   \"employee_supervisor_id\" integer,\n" +                 "   \"employee_clockstatus\" BOOLEAN DEFAULT 'false',\n"+      // True = IN : False = OUT                "   \"employee_lastpunch\" timestamp, \n"+                "   \"employee_isactive\" BOOLEAN, \n"+                "   CONSTRAINT employee_pk PRIMARY KEY (\"employee_id\")\n" +                 ") WITH (\n" +                 "  OIDS=FALSE\n" +                 ");\n";老實說,我認為 SQL 并不重要。大約 6 個月前,這句話對我有用。我不知道發生了什么變化,但我從 Postgresql 9.4 更改為 10.7?無論最新的 10.x 穩定版是什么。我將 Gradle 更新為// https://mvnrepository.com/artifact/org.postgresql/postgresqlcompile group: 'org.postgresql', name: 'postgresql', version: '42.2.6'
查看完整描述

1 回答

?
白板的微信

TA貢獻1883條經驗 獲得超3個贊

您不能將CREATE TABLE語句與 RETURNING 子句結合使用(因為它不會“返回”任何內容)。

當您調用時,executeUpdate(query,Statement.RETURN_GENERATED_KEYS)您請求返回 DML 語句生成的密鑰。RETURNINGPostgres JDBC 驅動程序通過向查詢添加一個子句來實現這一點——這顯然對 DDL 語句沒有意義。

改用execute(query)

或者executeUpdate(query)(不請求生成的密鑰)


查看完整回答
反對 回復 2023-03-02
  • 1 回答
  • 0 關注
  • 257 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號