Postgresql 错误:Java DELETE 操作中“列不存在”
尝试使用 Java 和 PostgreSQL 进行 DELETE 操作时,可能会遇到错误“列‘column_name’不存在。”当相关列名包含大写字母时,就会出现此问题。
在 PostgreSQL 中,如果数据库标识符(例如表名和列名)包含大写字符,则必须用引号引起来。这是因为默认模式搜索路径不区分大小写,并且引用可确保使用准确的名称。
解决方案:
要解决该错误,只需放置SQL 语句中的列名用双引号括起来:
String stm = "DELETE FROM hostdetails WHERE \"MAC\" = 'kzhdf'";
或者,您可以使用字符串插值来动态构建带引号的列名的 SQL 语句:
String column = "MAC"; String stm = String.format("DELETE FROM hostdetails WHERE \"%s\" = 'kzhdf'", column);
其他注意事项:
使用准备好的语句时,建议避免直接在 SQL 字符串中设置查询参数。相反,使用PreparedStatement的方法来绑定参数:
pst.setString(1, "kzhdf");
这可以防止潜在的SQL注入漏洞并使代码更易于维护。
以上是为什么我的 Java 中的 PostgreSQL DELETE 语句失败并显示'列不存在”?的详细内容。更多信息请关注PHP中文网其他相关文章!