[英]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.