zhl910114 2014-12-13 07:45 采纳率: 11.1%
浏览 1840

mysql查询出错,求绑帮忙解决,谢谢了!

下面是我的代码:
List params = new ArrayList();
StringBuffer sb = new StringBuffer();

    //外层查询
    sb.append("select * from ( ");
    sb.append(" select * from admin_info ");
    sb.append(" where 1=1 ");

    if(roleId != null){
    //拼第一个条件
    sb.append(" and id in ( ");
    sb.append(" select admin_id from admin_role ar ");
    sb.append(" inner join role_info ri on ri.id=ar.role_id ");
    sb.append(" where ri.id=? ");
    sb.append(" )");
    params.add(roleId);
    }
    if(privilegeId != null){
    //拼第二个条件
    sb.append(" and id in ( ");
    sb.append(" select admin_id from admin_role ar ");
    sb.append(" inner join role_info ri on ri.id=ar.role_id ");
    sb.append(" inner join role_privilege rp on ri.id=rp.role_id ");
    sb.append(" where rp.privilege=? ");
    sb.append(" )");
    params.add(privilegeId);
    }
    //拼分页条件
    sb.append(" ) admin_info limit ?,? ");

    params.add((page-1)*pageSize);
    params.add(pageSize);


    这是控制台报的错误:
    java.sql.SQLException: No value specified for parameter 2
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:987)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:982)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:927)
at com.mysql.jdbc.PreparedStatement.checkAllParametersSet(PreparedStatement.java:2578)
at com.mysql.jdbc.PreparedStatement.fillSendPacket(PreparedStatement.java:2554)
at com.mysql.jdbc.PreparedStatement.fillSendPacket(PreparedStatement.java:2480)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2234)
at com.dao.admin.AdminDAOImpl.findByCondition(AdminDAOImpl.java:67)
at com.dao.admin.AdminDAOImpl.main(AdminDAOImpl.java:118)

Exception in thread "main" java.lang.Exception: 查询管理员失败!
at com.dao.admin.AdminDAOImpl.findByCondition(AdminDAOImpl.java:93)
at com.dao.admin.AdminDAOImpl.main(AdminDAOImpl.java:118)
Caused by: java.sql.SQLException: No value specified for parameter 2
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:987)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:982)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:927)
at com.mysql.jdbc.PreparedStatement.checkAllParametersSet(PreparedStatement.java:2578)
at com.mysql.jdbc.PreparedStatement.fillSendPacket(PreparedStatement.java:2554)
at com.mysql.jdbc.PreparedStatement.fillSendPacket(PreparedStatement.java:2480)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2234)
at com.dao.admin.AdminDAOImpl.findByCondition(AdminDAOImpl.java:67)
... 1 more

  • 写回答

3条回答 默认 最新

  • 微wx笑 Java领域优质创作者 2014-12-13 08:31
    关注

    No value specified for parameter 2
    第二个参数没有赋值。

    评论

报告相同问题?

悬赏问题

  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B
  • ¥15 想问一下stata17中这段代码哪里有问题呀