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

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

Susan Sarandon
发布: 2024-12-19 10:10:10
原创
764 人浏览过

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

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板