1、山东商业职业技术学院Java程序设计课程开发组JDBC查询数据表2 2 学习目标知识目标掌握ResultSet接口的使用掌握结果集对象的关闭能力目标能够使用Statement对象实现数据查询操作能够使用ResultSet对象处理结果集数据3 3 使用JDBC维护SQL Server数据库表中的数据,对数据表进行查询操作在Java中如何实现数据表的查询操作?使用JDBC查询SQL Server数据库4 4 JDBC访问数据库的步骤1个准备8个步骤8开 始加载并注册驱动程序创建一个 Connection 对象创建一个 Statement 对象执行语句关闭ResultSet 对象关闭Statemen
2、t对象关闭连接结 束使用ResultSet对象1234576添加JDBC驱动jar包 1个准备个准备5 5 JDBC工作步骤第四步try String sql = “select查询语句”; ResultSResultSetet rs = stmt.executeQuery(sql); catch (SQLException e) e.printStackTrace(); 第四步:执行SQL语句,获得ResultSet对象executeQuery()方法返回值为方法返回值为ResultSet对象,对象,存放的是执行存放的是执行select语句时符合查询条件的结果语句时符合查询条件的结果以下为执
3、行查询员工信息示例:try String sql = “select empNo, eName, eSex from emp”; ResultSet rs = stmt.executeQuery(sql); catch (SQLException e) e.printStackTrace(); 6 6 JDBC工作步骤第五步2-1try while(rs.nextrs.next() () 变量名 = rs.getXXXrs.getXXX(” (” 字段名字段名”); ”); catch (SQLException e) e.printStackTrace(); 第五步:使用ResultSet对
4、象循环遍历结果集1.变量名和字段名的数据类型相同变量名和字段名的数据类型相同2.getXXX方法的方法的XXX是字段名对应的数据类型是字段名对应的数据类型7 7 JDBC工作步骤第五步2-2 第五步:使用ResultSet对象循环遍历结果集以下为执行查询员工信息和打印显示示例:try while(rs.next() int empNo = rs.getInt(”empNo”); String eName = rs.getString(”eName”); String eSex = rs.getString(”eSex”); catch (SQLException e) e.printStack
5、Trace(); 8 8 JDBC工作步骤第六步try if(rs != null) rs.closers.close();(); catch (SQLException e) e.printStackTrace(); 第六步:关闭ResultSet结果集对象9 9 JDBC工作步骤第七步try if(stmt != null) stmt.closestmt.close();(); catch (SQLException e) e.printStackTrace(); 第七步:关闭Statement语句对象1010 JDBC工作步骤第八步try if(con != null & !con.is
6、Closed() con.closecon.close();(); catch (SQLException e) e.printStackTrace(); 第八步:关闭Connection语句对象1111 JDBC实现查询数据表数据3-1try Class.forName(com.microsoft.sqlserver.jdbc.SQLServerDriver); catch (ClassNotFoundException e) System.out.println(无法找到驱动类);Connection con = null; Statement stmt = null; ResultSet
7、 rs = null; 通过JDBC查询empmanage数据库的emps表中所有员工信息1212 JDBC实现查询数据表数据3-2try con = DriverManager.getConnection(“”, “, “); stmt = con.createStatement(); String sql = “select empNo, eName, eSex from emp”; ResultSet rs = stmt.executeQuery(sql); while(rs.next() int empNo = rs.getInt(”empNo”); String eName = rs
8、.getString(”eName”); String eSex = rs.getString(”eSex”); System.out.println(empNo + “t” + eName + “t” + eSex); 1313 JDBC实现往数据表添加数据3-3catch (SQLException e) e.printStackTrace(); finally try if(rs != null) rs.close(); if(stmt != null) stmt.close(); if(con != null & !con.isClosed() con.close(); catch (
9、SQLException e) e.printStackTrace(); 1414 知识点小结1.1.语句对象执行查询语句的方法是什么语句对象执行查询语句的方法是什么2.2.语句对象执行增删改查语句的方法是什么语句对象执行增删改查语句的方法是什么3.3.如何判断结果集中是否还有数据行如何判断结果集中是否还有数据行4.4.如何获取结果集中对应行的字段取值如何获取结果集中对应行的字段取值1515 JDBC工作模板try Class.forNameClass.forName(JDBC(JDBC驱动类驱动类); ); catch (ClassNotFoundException e) System.ou
10、t.println(无法找到驱动类); Connection con = null; Statement stmt = null; ResultSet rs = null;try con=DriverManager.getConnectionDriverManager.getConnection(JDBC (JDBC URL,URL,数据库用户名数据库用户名, ,密码密码); ); stmt = con.createStatementcon.createStatement() (); rs = stmt.executeQuerystmt.executeQuery(SELECT a, b, c
11、FROM Table1); while (rs.nextrs.next() () int x = rs.getInt(a); String s = rs.getString(b); float f = rs.getFloat(c); catch (SQLException e) e.printStackTrace();finally try rs.closers.close(); (); stmt.closestmt.close(); (); con.closecon.close(); (); catch(SQLException e) . 第 一 步第 二 步第 三 步第 四 步第 七 步第 八 步第 五 步第 六 步山东商业职业技术学院Java程序设计课程开发组感谢您的学习