java jdbc 分页_Java jdbc中的多条件分页查询

该博客主要讨论了一个Java JDBC实现的多条件分页查询中遇到的问题,即查询总数始终等于MySQL数据库的总记录数,没有根据条件进行过滤。代码展示了一个名为`tongJi`的方法,用于统计满足特定条件的学生数量。方法中根据传入的对象`sdtj`的属性动态拼接SQL语句,并使用PreparedStatement设置参数。然而,问题在于代码似乎没有进入if语句执行条件判断部分,导致查询未按预期过滤数据。博主寻求帮助找出为何没有进入if语句。
摘要由CSDN通过智能技术生成

无论我加几种查询条件,返回给我的查询总量恒等于mysql数据的总量

经过逐行打印,发现没有进入if语句中

问题:帮忙找出为什么没有进入if语句中????

public static int tongJi(StudentDuoTiaoJian sdtj) {

Connection conn = null;

ResultSet rs = null;

PreparedStatement ps = null;

conn = Util.getConnection();

StringBuilder sql = new StringBuilder();

sql.append("  select count(*)");

sql.append("  from stu_student");

sql.append("  where 1=1");

if (sdtj.getId() != 0) {

sql.append(" and stu_id=?");

System.out.println("==============================");

}

if (sdtj.getName() != null) {

sql.append(" and stu_name like ?");

System.out.println("==============================");

}

if (sdtj.getNianji() != 0) {

sql.append("  and stu_nianji=?");

System.out.println("==============================");

}

if (sdtj.getPsw() != null) {

sql.append("  and stu_psw=?");

System.out.println("==============================");

}

if (sdtj.getIdNo() != 0) {

sql.append("  and stu_id>=?");

System.out.println("==============================");

}

if (sdtj.getIdEnd() != 0) {

sql.append("  and stu_id<=?");

System.out.println("==============================");

}

int a = 0;

try {

ps = conn.prepareStatement(sql.toString());

if (sdtj.getId() != 0) {

ps.setInt(++a, sdtj.getId());

System.out.println(a);

}

if (sdtj.getName() != null) {

ps.setString(++a, sdtj.getName());

System.out.println(a);

}

if (sdtj.getNianji() != 0) {

ps.setInt(++a, sdtj.getNianji());

System.out.println(a);

}

if (sdtj.getPsw() != null) {

ps.setString(++a, sdtj.getPsw());

System.out.println(a);

}

if (sdtj.getIdNo() != 0) {

ps.setInt(++a, sdtj.getIdNo());

System.out.println(a);

}

if (sdtj.getIdEnd() != 0) {

ps.setInt(++a, sdtj.getIdEnd());

System.out.println(a);

}

rs = ps.executeQuery();

if (rs.next()) {

int num = rs.getInt(1);

System.out.println(num);

return num;

}else{

return 0;

}

} catch (SQLException e1) {

// TODO Auto-generated catch block

e1.printStackTrace();

return 0;

}finally {

Util.close(conn, ps, rs);

}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值