[java,jdbc,PostgreSQL]动态传递表名进行查询时报错

在尝试使用Java的JDBC连接PostgreSQL数据库并动态设置表名进行查询时,遇到了错误。问题出在PreparedStatement的SQL语句上,`?`占位符无法用于表名。为解决这个问题,需要重新构造SQL语句,避免使用预编译的占位符来指定表名。
摘要由CSDN通过智能技术生成

我想写一段公用的程序,根据表名称的不同,查询不同的表。
当我执行如下方法时报错,求解:

public static void test() {
Logger logger = Logger.getLogger(TreeListAction.class);
try {
Class.forName("org.postgresql.Driver");
Connection cn = DriverManager.getConnection("jdbc:postgresql://127.0.0.1:5432/my_show ", "developer",
"developer");
PreparedStatement ps = cn.prepareStatement("select * from ? where parentNodeId = ? ");
ps.setString(1,"base_help_tree_node");
ps.setInt(2,0); //设定参数值
ps.executeQuery(); //获得查询结果
} catch (Exception ex) {
logger.error("出问题了:", ex);
logger.error("end出问题了");
}
}
报错如下:
[ERROR][2011-02-16 16:48:14 875][http-801-1] help.controller.TreeListAction - 出问题了:
org.postgresql.ut

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值