我对此将非常简单。即使调用setString()之后,发送到准备好的语句的问号仍然是一个问号。为什么会这样呢?
package com.orangeandbronze.buyfromus.dao;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import com.orangeandbronze.buyfromus.model.User;
import com.mchange.v2.c3p0.impl.NewProxyConnection;
public class UserDaoPooled implements UserDao {
@Override
public User findByUsername(String username) throws DataAccessException{
// TODO Auto-generated method stub
NewProxyConnection conn = (NewProxyConnection)ConnectionManager.getInstance().getConnection();
StringBuilder queryBuilder = new StringBuilder("");
queryBuilder.append("SELECT fld_username,fld_password,fld_role_type");
queryBuilder.append("FROM tbl_user WHERE username= ? ");
queryBuilder.append("AND tbl_role.key_role=tbl_user.key_role");
String query = queryBuilder.toString();
try {
PreparedStatement stmt;
stmt = conn.prepareStatement(queryBuilder.toString());
stmt.setString(1, username);
ResultSet rs = stmt.executeQuery(query);
rs.last(); //move to last row and get current position
int rowCount = rs.getRow();
if(rowCount==1){
return new User(rs.getString(1),rs.getString(2),rs.getString(3));
}
else{
return null;
}
}catch (SQLException e) {
throw new DataAccessException("Unable to connect to our database servers",e);
}
}
}
最佳答案
您已经在prepareStatement
语句中设置了查询并绑定了变量-无需在executeQuery
中再次提供查询,即:
PreparedStatement stmt;
stmt = conn.prepareStatement(queryBuilder.toString());
stmt.setString(1, username);
ResultSet rs = stmt.executeQuery(); <-- No query
这也意味着前面对
String query = queryBuilder.toString();
的调用也是多余的,可以删除。关于java - setString()中未替换JDBC和c3p0 PreparedStatement中的问号占位符,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/23622643/