zoukankan      html  css  js  c++  java
  • 【原】关于executeQuery与ResultSet

    今天老实犯糊涂,再总结一下以前的知识吧~

    executeQuery()永远不会返回null

    这一点很重要,也很容易让人忽视。举个例子吧;
    比如,在数据库中,只有两个用户user1,user2的密码是“123”。那么运行下面代码的结果是什么呢?

    ......
    
                    String sql = "select uname from user where  upwd = ?";
    		PreparedStatement pst = conn.prepareStatement(sql);
    		pst.setString(1, "123");
    		ResultSet rs = null;
    		rs = pst.executeQuery();//此时rs里面有两条数据
    		System.out.println(rs.next());//<font color=red>不是打印user1,而是打印true</font>
    		System.out.println(rs.next());//不是打印user2,而是打印true
    		System.out.println(rs.next());//打印false,由于每次调用next()的作用是向后移动一条数据,所以现在已经到了第三条数据,而rs里面一共有两条数据
    		
    ......
    
    

    那么如果想得到user1,user2,该怎么办呢?如下:

    ......
    
                    String sql = "select uname from user where  upwd = ?";
    		PreparedStatement pst = conn.prepareStatement(sql);
    		pst.setString(1, "123");
    		ResultSet rs = null;
    		rs = pst.executeQuery();//此时rs里面有两条数据
    		
    		while(rs.next()){
    			System.out.println(rs.getString("uname"));//这样就能输出user1,user2了
    		}
    ......
    
    
  • 相关阅读:
    ajax三级联动
    ajax基础
    pdo连接数据
    jquery选择器和基本语句
    会话
    封装连接类
    1218数据访问
    php登陆与注册
    数据库连接和乱码问题
    mysql 严格模式 Strict Mode说明(text 字段不能加默认或者 不能加null值得修改方法)
  • 原文地址:https://www.cnblogs.com/seven7seven/p/3991507.html
Copyright © 2011-2022 走看看