Java 用msql LIKE语句模糊查询——prepareStatement LIKE语句

Java 用msql LIKE语句模糊查询——prepareStatement LIKE语句

问题:
prepareStatement LIKE在mysql中可以输出结果,但是用java写就查找不到结果。

public void getYunEventListByKw(String content) {

		PreparedStatement preStmt = null;
		ResultSet rs = null;
		Connection conn = null;
		try {
			conn = dbHelper.getYunshanConnection();

			//**重点内容**
			String sql = "SELECT * FROM yunshan_event WHERE event_summary LIKE ?";
			 preStmt = conn.prepareStatement(sql);
			 
			 preStmt.setString(1, "%"+content+"%");
			 System.out.println(content);
			 rs = preStmt.executeQuery();
			 System.out.println(preStmt.toString());
			//***
			while (rs.next()) {
				int eventId = rs.getInt("id");
			}
		} catch (SQLException se) {
			se.printStackTrace();
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			dbHelper.closeAll(conn, preStmt, rs);
		}
		return null;
	}

我一直搜索不出结果,看了最后我打印出来那个最后的sql语句。
竟然是这个样子:

com.mysql.jdbc.JDBC4PreparedStatement@5dbe6544: SELECT * FROM yunshan_event WHERE event_summary LIKE '%??%'

原来是因为jdbc连接的时候没有设置utf8的编码,所以会乱码,一直搜索不到内容.

String DB_URL = "jdbc:mysql://192.168.235.36:3306/fig?zeroDateTimeBehavior=round&characterEncoding=utf8"; 

搞定。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值