首頁 > 資料庫 > mysql教程 > 為什麼從 PostgreSQL 刪除時我的 Java 程式碼會拋出「列不存在」錯誤?

為什麼從 PostgreSQL 刪除時我的 Java 程式碼會拋出「列不存在」錯誤?

Mary-Kate Olsen
發布: 2024-12-27 05:43:13
原創
321 人瀏覽過

Why Does My Java Code Throw a

錯誤:使用Java 從PostgreSQL 刪除時列不存在

簡介

將Java 程式連接到PostgreSQL 並執行CRUD 操作對於許多人來說至關重要應用程式。本文解決了嘗試使用 Java 從 PostgreSQL 表中刪除資料時遇到的常見錯誤。

錯誤

執行以下程式碼時:

con = DriverManager.getConnection(url, user, password);
String stm = "DELETE FROM hostdetails WHERE MAC = 'kzhdf'";
pst = con.prepareStatement(stm);
pst.executeUpdate();
登入後複製

使用者可能會遇到錯誤:

SEVERE: ERROR: column "mac" does not exist
登入後複製

解決方法

使用PostgreSQL時,實體名稱具有大寫字母的(例如表格和欄位)必須使用雙引號(「」)進行「轉義」。因此,正確的程式碼是:

String stm = "DELETE FROM hostdetails WHERE \"MAC\" = 'kzhdf'";
登入後複製

準備語句最佳實踐

此外,建議使用準備語句以獲得更好的安全性和效能。程式碼應更新如下:

con = DriverManager.getConnection(url, user, password);
String stm = "DELETE FROM hostdetails WHERE \"MAC\" = ?";
pst = con.prepareStatement(stm);
pst.setString(1, "kzhdf");
pst.executeUpdate();
登入後複製

以上是為什麼從 PostgreSQL 刪除時我的 Java 程式碼會拋出「列不存在」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板