首页 >数据库 >mysql教程 >为什么我的 Java 中的 PostgreSQL DELETE 语句失败并显示'列不存在”?

为什么我的 Java 中的 PostgreSQL DELETE 语句失败并显示'列不存在”?

Susan Sarandon
Susan Sarandon原创
2024-12-19 10:10:10766浏览

Why Does My PostgreSQL DELETE Statement in Java Fail with

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn