mysql拼接sql带参数,sql拼接

69d70a253fd4c220c1c5f52ed1d6cb8e.png

模棱0

2016-10-26 21:53

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 paramList = new ArrayList();

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 messageList = new ArrayList();

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);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值