博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JDBC
阅读量:4935 次
发布时间:2019-06-11

本文共 3307 字,大约阅读时间需要 11 分钟。

1,JDBC架构:

  1. JDBC API支持两层和三层处理模型进行数据库访问,但在一般的JDBC体系结构由两层组成:
  2. JDBC API: 提供了应用程序对JDBC的管理连接。
  3. JDBC Driver API: 支持JDBC管理到驱动器连接。
  4. JDBC API的使用驱动程序管理器和数据库特定的驱动程序提供透明的连接到异构数据库。
  5. JDBC驱动程序管理器可确保正确的驱动程序来访问每个数据源。该驱动程序管理器能够支持连接到多个异构数据库的多个并发的驱动程序。

以下是结构图,它显示了驱动程序管理器方面的JDBC驱动程序和Java应用程序的位置:

2,常见的JDBC组件:

  1. JDBC API提供了以下接口和类:
  2. DriverManager: 这个类管理数据库驱动程序的列表。内容是否符合从Java应用程序使用的通信子协议正确的数据库驱动程序的连接请求。识别JDBC在一定子协议的第一个驱动器将被用来建立数据库连接。
  3. Driver: 此接口处理与数据库服务器通信。很少直接与驱动程序对象。相反,使用DriverManager中的对象,它管理此类型的对象。它也抽象与驱动程序对象工作相关的详细信息
  4. Connection : 此接口与接触数据库的所有方法。连接对象表示通信上下文,即,与数据库中的所有的通信是通过唯一的连接对象。
  5. Statement : 可以使用这个接口创建的对象的SQL语句提交到数据库。一些派生的接口接受除执行存储过程的参数。
  6. ResultSet: 这些对象保存从数据库后,执行使用Statement对象的SQL查询中检索数据。它作为一个迭代器,让您可以通过移动它的数据。
  7. SQLException: 这个类处理发生在一个数据库应用程序的任何错误。

3,创建JDBC应用程序

  1. 导入数据报(需要包括含有须有进行数据库编程的JDBC类的包,大多数情况下,使用import java.sql.*就可以了)
  2. 注册JDBC驱动程序(需要初始化驱动程序,可以与数据库打开一个通信通道)
  3. 打开连接(需要使用DriverManager.getConnection()方法创建一个Connection对象,它代表与数据库的物理连接);
  4. 执行查询(需要使用类型声明的对象建立并提交一个SQL语句到数据库)
  5. 从结果集中提取数据(要求使用适当的关于ResultSet.getXXX()方法来检索结果集的数据
  6. 需要明确地关闭所有的数据库资源相对依靠JVM的垃圾收集
import java.sql.*;public class FirstExample {   // JDBC driver name and database URL   static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";     static final String DB_URL = "jdbc:mysql://localhost:3306/EMP";   //  Database credentials   static final String USER = "root";   static final String PASSWORD = "";      public static void main(String[] args) {   Connection conn = null;   Statement stmt = null;   try{      //STEP 2: Register JDBC driver      Class.forName("com.mysql.jdbc.Driver");      //STEP 3: Open a connection      System.out.println("Connecting to database...");      conn = DriverManager.getConnection(DB_URL,USER,PASSWORD);      //STEP 4: Execute a query      System.out.println("Creating statement...");      stmt = conn.createStatement();      String sql;      sql = "SELECT id, first, last, age FROM Employees";      ResultSet rs = stmt.executeQuery(sql);      //STEP 5: Extract data from result set      while(rs.next()){         //Retrieve by column name         int id  = rs.getInt("id");         int age = rs.getInt("age");         String first = rs.getString("first");         String last = rs.getString("last");         //Display values         System.out.print("ID: " + id);         System.out.print(", Age: " + age);         System.out.print(", First: " + first);         System.out.println(", Last: " + last);      }      //STEP 6: Clean-up environment      rs.close();      stmt.close();      conn.close();   }catch(SQLException se){      //Handle errors for JDBC      se.printStackTrace();   }catch(Exception e){      //Handle errors for Class.forName      e.printStackTrace();   }finally{      //finally block used to close resources      try{         if(stmt!=null)            stmt.close();      }catch(SQLException se2){      }// nothing we can do      try{         if(conn!=null)            conn.close();      }catch(SQLException se){         se.printStackTrace();      }//end finally try   }//end try   System.out.println("Goodbye!");}//end main}//end FirstExampleoutput:Connecting to database...Creating statement...ID: 100, Age: 18, First: Zara, Last: AliID: 101, Age: 25, First: Mahnaz, Last: FatmaID: 102, Age: 30, First: Zaid, Last: KhanID: 103, Age: 28, First: Sumit, Last: Mittal

 

转载于:https://www.cnblogs.com/lemon-now/p/5530043.html

你可能感兴趣的文章
网站开发 关于图片压缩 以及图片使用
查看>>
hive的count(distinct id)测试--慎用
查看>>
第九周周总结
查看>>
Logistic Regression
查看>>
8lession-基础类型转化
查看>>
FlashCS5作成SWC,在Flex4中使用(1)
查看>>
vue-cli目录结构及说明
查看>>
JS 数据类型转换
查看>>
WeQuant交易策略—RSI
查看>>
osgearth将视点绑定到一个节点上
查看>>
PHP 当前时间秒数+数值,然后再转换成时间。
查看>>
数据交互 axios 的使用
查看>>
bootloader,kernel,initrc
查看>>
Java中jshell脚本
查看>>
performSelector的方法
查看>>
redis
查看>>
BZOJ1645 [Usaco2007 Open]City Horizon 城市地平线
查看>>
配置IIS
查看>>
单例模式详解
查看>>
电商项目(下)
查看>>