亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

sql拼接

我的參數沒亂碼,sql卻成了select ID,COMMAND,DESCRIPTION,CONTENT from message where 1=1 and COMMAND = ? ? select ID,COMMAND,DESCRIPTION,CONTENT from message where 1=1 and DESCRIPTION like '%' ? '%' 參數就沒替換上去,這是為什么?那位大神能幫我解決一下

正在回答

2 回答

req.setCharacterEncoding("utf-8");

try {

String command = req.getParameter("command");

String description = req.getParameter("description");

req.setAttribute("command", command);

req.setAttribute("description", description);

Class.forName("com.mysql.jdbc.Driver");

Connection connection = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/micro_message", "root", "root");

StringBuilder sql = new StringBuilder("select ID,COMMAND,DESCRIPTION,CONTENT from MESSAGE where 1=1");

List<String> paramList = new ArrayList<String>();

if (command != null && !"".equals(command.trim())) {

sql.append(" and COMMAND = ?"); //先把拼接的模版做好,最后在通過%把傳過來的參數加進去

paramList.add(command);

} ? ? ? ? ? ? ? ? ? ?

if (description != null && !"".equals(description.trim())) {

sql.append(" and DESCRIPTION like '%' ? '%'");

paramList.add(description);

}

PreparedStatement statement = (PreparedStatement) connection.prepareStatement(sql.toString());

System.out.println(paramList.size());

for (int i = 0; i < paramList.size(); i++) {

statement.setString(i+1, paramList.get(i));//sql語句中出現的?是從第一個開始數

}

System.out.println(sql.toString());

ResultSet resultSet = statement.executeQuery();

List<Message> messageList = new ArrayList<Message>();

while(resultSet.next()){

Message message = new Message();

messageList.add(message);

message.setId(resultSet.getString("ID"));

//System.out.println(resultSet.getString("ID"));

message.setCommand(resultSet.getString("COMMAND"));

message.setDescription(resultSet.getString("DESCRIPTION"));

message.setContent(resultSet.getString("CONTENT"));

}

req.setAttribute("messageList", messageList);


0 回復 有任何疑惑可以回復我~

把代碼貼出來

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
通過自動回復機器人學Mybatis---基礎版
  • 參與學習       107414    人
  • 解答問題       831    個

微信公眾號自動回復功能學習Mybatis,基礎教程加案例實戰方式學習

進入課程
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號