xiangzi_815 2011-08-25 14:04
浏览 199
已采纳

如何动态获取字段?

for (int i = 0; i < 30; i++) {
StringBuffer hql =new StringBuffer("");
hql.append("select ");
hql.append(sql1+" from (");
hql.append("select t."+sql1);
hql.append(",rownum as rm from ");
hql.append(sql2+" t)");
hql.append("where rm between "+((i)*50000+1)+" and "+((i+1)*50000));

        System.out.println(hql);
    System.out.println("等待中...");
    PreparedStatement ps = myConnect.prepareStatement(hql.toString());
    //多个参数
//  if (params != null) {
//      for (int i = 0; i < params.length; i++) {
//          ps.setString(i + 1, params[i]);
//      }
//  }

    ResultSet rs = ps.executeQuery();   
    StringBuffer  buffer = new StringBuffer();
    while (rs.next()) {
        buffer.append(rs.getString("DPTNO")+" ");
        buffer.append(rs.getString("OPTNO")+" ");
        buffer.append(rs.getString("CURR")+f+(h.equals("Y")?"\r\n":""));

    }

        System.out.println(buffer.toString());

while 里的字段是定死,我想动态的使用。。查询时,想要哪个字段就查哪个。

  • 写回答

6条回答 默认 最新

  • freishlove 2011-08-25 14:10
    关注

    ResultSetMetaData rsmd = rs.getMetaData()
    int columnCount = rsmd.getColumnCount();

    while(rs.next) {
    for(int i=1; i<=columnCount; i++) {
    buffer.append(rs.getString(i));
    }
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥50 求解vmware的网络模式问题
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳
  • ¥15 springboot 3.0 实现Security 6.x版本集成
  • ¥15 PHP-8.1 镜像无法用dockerfile里的CMD命令启动 只能进入容器启动,如何解决?(操作系统-ubuntu)
  • ¥30 请帮我解决一下下面六个代码
  • ¥15 关于资源监视工具的e-care有知道的嘛
  • ¥35 MIMO天线稀疏阵列排布问题
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?