浅谈JDBC(一)

时间:2023-03-08 18:01:38

一、JDBC技术引言

  1、什么是JDBC技术

     提供了一套接口规范,利用java代码进行数据库操作。

  2、JDBC技术的核心思想

    浅谈JDBC(一)

    对于程序员来说,代码访问数据库分为三个步骤:1、通过数据库的账号密码。2、用代码执行sql语句。3、接收查询的结果并展示。并且这些步骤应该是规避数据库差异的,不同的数据库产品应该用同一套规范代码。而java所提供的三个基础接口正是起的这个作用:Connection、PreparedStatement、ResultSet。java要求不通的数据库公司根据java所提供的接口来写相应的驱动jar包,这样的话,程序员就只需根据不同的数据库产品导入相应的驱动jar包即可,而编程步骤则是没有改变的。

二、基础代码

  1、JDBCUtil的简单版本实现(mysql)

    

 public class JDBCUtil{        static{      Class.forName("com.mysql.jdbc.Driver");
    }
     //创建连接
     public static Connection getConnection() throws Exception{
         //加载驱动
         Conection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test","root","12345678");       return conn;
     }

     //关闭资源
     public static void close(Conection conn,PreparedStatement pstmt,ResultSet rs){
         if(rs!=null){
             rs.close();
         }
         if(pstmt!null){
             pstmt.close();
         }
         if(conn!=null){
             conn.close();
         }
 }

  这段代码是对jdbc重复操作的简单封装,主要将拿连接和关闭资源的操作封装成了静态方法,方便以后使用。

  2、JDBC的编程步骤

    a、环境搭建  导入数据库相关的驱动jar

    b、加载驱动 将对应的数据库产品对于3个接口的实现 读入程序中。

    c、创建连接Connection  注意:提供用户名 密码。

    d、创建PreparedStatement 执行sql语句  注意 提供sql语句

    e、若进行的查询操作,ResultSet应处理查询结果

    f、关闭资源。

 String sql = "select * form t_user where name =? ";
 PreparedStatement pstmt = conn.prepareStatement(sql);
 pstmt.setString("Lee");
 ResultSet rs = pstmt.executeQuery();

    这段是d、e步骤的简单代码:

    可以看到PreparedStatement对象是通过Connection对象获得的,获得的同时可以传入需要执行的sql语句。而传入的sql语句是含有占位符"?"的,占位符的内容也是由PreparedStatement对象下的方法来进行填充的,其中的方法不仅有上述的setString,还有setInt()、setDouble()、setDate()等多种方法。最后是用PreparedStatement对象下的executeQuery()来返回所查询的结果集,其中的方法有三种:

    a、public ResultSet executeQuery()  返回一个不为空的结果集

    b、public int executeUpdate()  返回值有两个:(1)返回insert、update或者delete语句执行后的影响行数。(2)返回0表示sql语句没有执行成功。

    c、public boolean execute()  返回ture:表示sql语句执行的结果为ResultSet对象,返回false表示sql语句执行结果为影响行数或者没有返回。

    如何遍历ResultSet对象:

 //代码仅为示例
 while(resultSet.next()){
     Book book = new Book();
     book.setBookName(resultSet.getString("bookName"));
     book.setPrice(resultSet.getString("price"));
     book.setPicUrl(resultSet.getString("picUrl"));
     list.add(book);
  }

    可以想象ResultSet对象中存有多条数据,ResultSet对象有next()方法,该方法的内部有一个指针指向当前该条数据,如果指针下有数据,执行next()方法的时候返回的是true,next()方法执行完之后,指针自动跳到下一条数据上。所以用while循环,当指针指向null的时候,也是ResultSet对象中的数据遍历结束的时候,该while循环便终止。所有的数据就都存入到List集合中去了。