簡體   English   中英

JDBC查詢RETURNING值

[英]JDBC query RETURNING value

我試圖弄清楚如何使用PostgreSQL和JDBC獲取最后插入行的id有問題。

    CREATE TABLE vet_care (
        id serial PRIMARY KEY,
        deworming int,
        castration int
    );

我的疑問是

String insertVetCare = "INSERT INTO vet_care(castration,deworming) VALUES("+castrated+","+dewormed+") RETURNING id";

我想要id值(這是串行的)供以后使用。 我嘗試執行這樣的查詢:

int id = statement.executeUpdate(insertVetCare);

但是這在編譯之后說,“當沒有人預期時會返回結果。” 並且它不會將其他值插入表中。

我怎樣才能讓它發揮作用?

如果“id”表示“生成的身份密鑰”,那么你就錯了。

executeUpdate()方法根據javadocs返回受影響的行數。

您希望它返回自動生成的密鑰,如下所示

更多建議:使用PreparedStatement並綁定值。 構建一個SQL查詢就是要求SQL注入攻擊。

// Why make the gc work?  This query never changes.
private static final String INSERT_VET_CARE = "INSERT INTO vet_care(castration,deworming) VALUES(?, ?)";


PreparedStatement ps = connection.prepareStatement(INSERT_VET_CARE,  Statement.RETURN_GENERATED_KEYS);
ps.setInt(1, castration);
ps.setInt(2, deworming);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM