问答详情
源自:2-7 代码重构

模糊查询查不到东西怎么办?

package Servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import bean.Message;

@SuppressWarnings({ "serial", "unused" })
public class ListServlet extends HttpServlet {

	private static  String url = "jdbc:MYSQL://127.0.0.1:3306/micro_message";
	private static  String user = "root";
	private static  String password = "123456";

	/**
	 * Constructor of the object.
	 */
	public ListServlet() {
		super();
	}

	public void destroy() {
		super.destroy(); // Just puts "destroy" string in log
		// Put your code here
	}

	
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		try {
			Class.forName("com.mysql.jdbc.Driver");
			Connection conn = null;
			try {
				 request.setCharacterEncoding("utf-8");
				 response.setCharacterEncoding("utf-8");
				 String command=request.getParameter("command");
				 String description=request.getParameter("description");
				 request.setAttribute("command", command);
				 request.setAttribute("description", description);
				 conn = DriverManager.getConnection(url,user,password);
				 StringBuilder sql=new StringBuilder("select * from message where 1=1");
				 List<String> paramList=new ArrayList<String>();
				 if(command!=null&&!"".equals(command.trim())){
					 sql.append(" and command='"+command+"' ");
					 paramList.add(command);
				 }
				 if(description!=null&&!"".equals(description.trim())){
					 sql.append(" and DESCRIPTION like '%' ? '%'");
					 paramList.add(description);
				 }
				 PreparedStatement statement=conn.prepareStatement(sql.toString());
				 for(int i = 1;i<paramList.size();i++){
					 statement.setString(i, paramList.get(i));
				 }
				 ResultSet rs=statement.executeQuery(sql.toString());
				 List<Message> messageList=new ArrayList<Message>();
				 while(rs.next()){
					 Message message=new Message();
					 message.setId(rs.getInt("id"));
					 message.setCommand(rs.getString("command"));
					 message.setContent(rs.getString("content"));
					 message.setDescription(rs.getString("description"));
					 messageList.add(message);
				 }
				 request.setAttribute("messageList", messageList);
			} catch (SQLException e) {
				e.printStackTrace();
			}
			} catch (ClassNotFoundException e) {
				e.printStackTrace();
		}
		request.getRequestDispatcher("/WEB-INF/jsp/back/List.jsp").forward(request, response);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		this.doGet(request, response);
	}

	public void init() throws ServletException {
		// Put your code here
	}

}

报错是 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '? '%'' at line 1

提问者:二道桥十三太保 2017-04-06 19:20

个回答

  • 慕粉3796571
    2017-06-19 11:51:47
    已采纳

    sql.append(" and command='"+command+"' ");这一句写错了;

    改成sql.append(" and command= ? ");  或者sql.append(" and command="+command+" ");

  • 奔跑吧boys
    2017-04-08 08:37:44

    控制for循环

    1,如果存在description,不存在command,就循环一次,给参数赛值;

    2,如果description,command都存在,循环一次,给第二个参数赛值;

    3,如果command存在,description不存在,就不要循环,不要进行赛值;

    3,如果command,description都不存在,也不要进行参数赛值;

    备注:这里可以不用循环,可以直接取第几个参数,得到,并进行赛值;


  • 奔跑吧boys
    2017-04-06 22:45:10

    如果command为空,description为不为空,然后是不会进入for循环,这时,就不会statement.setString(i, paramList.get(i));    ->然后就会报sql错误