[英]Passing BIT in query as a parameter in Prepared Statement
我想传递一点作为 Prepared Statement 中的参数之一。 我的查询应该是这样的:
query = select * from tbl_security_details('user',O::BIT)
我将查询构造为:
query = select * from tbl_security_details(?,?)
PreparedStatement ps = connection.prepareStatement(query);
ps.setString(1,"user")
ps.setString(2,"0::BIT")
但是,这会引发错误。
有人可以解释我如何从准备语句中传递 0::BIT 而不用它自己附加单引号并转换为字符串吗?
编写准备好的语句,以便强制转换成为查询的一部分:
String query = "select * from tbl_security_details(?, ?::bit)";
java.sql.PreparedStatement ps = connection.prepareStatement(query);
ps.setString(1, "user");
ps.setString(2, "0");
这是必要的,因为您只能将常量值传递给准备好的语句,而不是 SQL 表达式。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.