java sql 参数_java 多参数 怎么写SQL查询?

下面是3个参数,如果五六个参数是不是也得这么判断???

@Override

public List getPins(String c, String categoryId, String q, Integer page, Integer perPage) {

q = "%" + q + "%";

if(perPage == null) {

perPage = PER_PAGE;

}

if(page == null) {

page = PAGE;

} else if(page > PAGE) {

page = (page - 1) * perPage;

}

if(StringUtils.isNotBlank(c) && StringUtils.isBlank(categoryId)) {

String sql = "SELECT p.* FROM tz_pin p, tz_file f WHERE p.deleting = 0 AND p.is_private = 0 AND p.file_id = f.file_id AND f.theme = ? AND p.raw_text LIKE ? ORDER BY p.pin_id DESC LIMIT ?, ?";

RowMapper rowMapper = new BeanPropertyRowMapper(Pin.class);

return jdbcTemplate.query(sql, rowMapper, c, q, page, perPage);

} else if(StringUtils.isBlank(c) && StringUtils.isNotBlank(categoryId)) {

String sql = "SELECT p.* FROM tz_pin p, tz_board b WHERE p.deleting = 0 AND p.is_private = 0 AND b.deleting = 0 AND p.board_id = b.board_id AND b.category_id = ? AND p.raw_text LIKE ? ORDER BY p.pin_id DESC LIMIT ?, ?";

RowMapper rowMapper = new BeanPropertyRowMapper(Pin.class);

return jdbcTemplate.query(sql, rowMapper, categoryId, q, page, perPage);

} else if(StringUtils.isNotBlank(c) && StringUtils.isNotBlank(categoryId)) {

String sql = "SELECT p.* FROM tz_pin p, tz_board b, tz_file f WHERE p.deleting = 0 AND p.is_private = 0 AND b.deleting = 0 AND p.board_id = b.board_id AND p.file_id = f.file_id AND f.theme = ? AND b.category_id = ? AND p.raw_text LIKE ? ORDER BY p.pin_id DESC LIMIT ?, ?";

RowMapper rowMapper = new BeanPropertyRowMapper(Pin.class);

return jdbcTemplate.query(sql, rowMapper, c, categoryId, q, page, perPage);

} else {

String sql = "SELECT * FROM tz_pin WHERE deleting = 0 AND is_private = 0 AND raw_text LIKE ? ORDER BY pin_id DESC LIMIT ?, ?";

RowMapper rowMapper = new BeanPropertyRowMapper(Pin.class);

return jdbcTemplate.query(sql, rowMapper, q, page, perPage);

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值