我想用 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 語句生成的密鑰。RETURNING
Postgres JDBC 驅動程序通過向查詢添加一個子句來實現這一點——這顯然對 DDL 語句沒有意義。
改用execute(query)
。
或者executeUpdate(query)
(不請求生成的密鑰)
添加回答
舉報
0/150
提交
取消