免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
论坛 程序设计 Java 无值
最近访问板块 发新帖
查看: 1573 | 回复: 5
打印 上一主题 下一主题

无值 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-07-31 20:48 |只看该作者 |倒序浏览
搞不清楚 我把sql语句打印出来 放在MYSQL-Front中查询 可以查询出值  但是在下面的代码中 rs.next()总是为false  要命的是没有报错  不知道到底出了什么问题 请各位大老 帮帮小弟


  1.         public Vector getInfor(int page,String kw,String st)
  2.         {
  3.                 Vector v=new Vector();
  4.                 String sql="";
  5.                        if(st.equals("1"))//歌手
  6.                        {
  7.                     sql="select * from ringall where author like binary '%"+kw+"%' order by date_time desc limit "+page*this.rowsPerPage+",5";
  8.                             }
  9.                       if(st.equals("2"))//歌名
  10.                        {
  11.                     sql="select * from ringall where name like binary  '%"+kw+"%' order by date_time desc limit "+page*this.rowsPerPage+",5";
  12.                              }
  13.                 try
  14.                 {
  15.                         System.out.println(sql);
  16.                         ResultSet rs=stmt.executeQuery(sql);
  17.                         System.out.println("rs1");
  18.                         System.out.print(rs.first());
  19.                         while(rs.next())
  20.                         {
  21.                                 System.out.println("rs2");
  22.                                 Ring_infor_bean rib=new Ring_infor_bean();
  23.                                 rib.setClassify(rs.getString("id"));
  24.                                 rib.setName(rs.getString("name"));
  25.                                 rib.setDotnum(rs.getInt("dotnum"));
  26.                                 rib.setDate_time(rs.getString("date_time"));
  27.                                 rib.setHypotaxis(rs.getString("hypotaxis"));
  28.                              rib.setAuthor(rs.getString("author"));
  29.                        
  30.                                 v.add(rib);
  31.                      }
  32.                         System.out.println(v.size());
  33.                 }
  34.                 catch(SQLException e)
  35.                 {
  36.                         System.out.println("ss1111ee");
  37.                         e.printStackTrace();
  38.                 }
  39.                 return v;
  40.         }
  41.         public void close_con()
  42.         {
  43.                 try
  44.                 {
  45.                     conn.close();
  46.                 }
  47.                 catch(SQLException e)
  48.                 {
  49.                         e.printStackTrace();
  50.                 }
  51.         }
复制代码

[ 本帖最后由 tree135311 于 2006-7-31 20:50 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2006-07-31 21:01 |只看该作者
try

Delete System.out.print(rs.first());

论坛徽章:
0
3 [报告]
发表于 2006-08-01 01:26 |只看该作者
System.out.print(rs.first());
while(rs.next())

除非你明确指明使用可滚动的ResultSet,否则默认的ResultSet都不是可滚动的,因为可滚动ResultSet性能上差了很多。所以你不能调用rs.first(),会导致rs.next()发生混乱。

论坛徽章:
0
4 [报告]
发表于 2006-08-01 08:56 |只看该作者
我去掉System.out.print(rs.first());
还是没有结果
System.out.println("rs2");
这条语句还是没有打印出来
恳请各位再帮小弟看看

论坛徽章:
0
5 [报告]
发表于 2006-08-01 10:37 |只看该作者
终于把问题解决了  原因是
con=DriverManager.getConnection("jdbc:mysql://127.0.0.1/sjswwap?useUnicode=true&characterEncoding=gbk","root","");

在这句中忘记加入"?useUnicode=true&characterEncoding=gbk"这句话
不好意思 因为这个小错误 浪费楼上两位的时间了

论坛徽章:
0
6 [报告]
发表于 2006-08-01 18:12 |只看该作者
十分感谢楼主能共享最后的解决方法!共享精神才是论坛的支柱
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP