说明:本系列学习笔记主要是学习传智播客的李勇老师的教学课程和一本英文电子书《JDBC Recipes A Problem-Solution Approach》所作的笔记。

1,什么是JDBC?

其实JDBC是API的一个集合,它允许你使用java语言对数据库操作。它的核心是接口,也有少量的类。它主要在java.sql和javax.sql两个包。

java.sql这个包主要是提供了一些访问并操作数据库的接口,这个包提供了大量的重要的objects (比如Connection, ResultSet, Statement, and PreparedStatement).

javax.sql则提供了服务端数据处理的接口。

下面的图是java应用使用java访问数据库的。

从这张图中可以看出,java应用程序使用JDBC的API对数据库进行访问,但是其中隔了许多的东西,有必要解释一下。

java应用程序通过JDBC应用程序接口访问JDBC’s DriverManager,这个JDBC驱动管理器管理许多不同的驱动,比如Oracle的、Mysql的驱动,当程序加载了某个驱动的时候,就会通过这个驱动访问某个数据库了。这些驱动当然都是各个数据库厂家实现的,但是都必须按照JDBC的API来实现。

下面是个简单的JDBC架构:它使用JDBC来访问数据库,但是省略了其中的细节。

下面是个详细的JDBC架构,它和我们文章的第一个图类似。

2,一个简单的例子

理论再天花乱坠,大家都不喜欢,整个简单的实例:

步骤:

1. Import the required packages.
2. Register the JDBC drivers.
3. Open a connection to a database.
4. Create a Statement object.
5. Execute a query and return a ResultSet object.
6. Process the ResultSet object.
7. Close the ResultSet and Statement objects.
8. Close the connection.

1,找到相关的驱动包,我这里新建一个简单的java工程,下载驱动包。我这里是连接Oracle数据库,所以就下载Oracle驱动。

2,注册JDBC驱动,这个你把包加入进来JVM是不识别的,你必须告诉它。

Class.forName("oracle.jdbc.driver.OracleDriver");

3,建立一个连接。

Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "scott", "scott");

4,创建一个Statement对象。

Statement stmt = conn.createStatement();

5,执行一个查询并返回一个结果。

ResultSet rs = stmt .executeUpdate(sql语句);

6,处理结果。

if (rs.next()) {
      String firstName = rs.getString(1);
      String lastName = rs.getString(2);
      String title = rs.getString(3);
      int salary = rs.getInt(4);
  }

7、8,关闭连接,主要是:conn ,stmt ,rs

下面再看一段最简单且不规范的程序。

package com.yfy;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class jdbcTest {
private static String sql = "select * from EMPLOYEES where first_name=?";
public static void main(String[] args) throws SQLException {
//1,注册驱动
DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
//2,建立连接
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "scott", "scott");
//3,创建语句
Statement stmt = conn.createStatement();
//4,执行语句,返回结果集
ResultSet rs = stmt.executeQuery(sql);
//5,处理结果
while (rs.next()) {
System.out.println("id:" + rs.getInt("EMPLOYEE_ID") + " first_name:" + rs.getString("first_name"));
}
//6,关闭连接
rs.close();
stmt.close();
conn.close();
}
}

看看数据库中的内容

执行之后的结果:

主要过程就是这些 ,但是需要注意,这些代码以后再优化,现在只是强调一个过程。下面这张图可以清晰的表达代码的流程。其中有些以后在介绍。

JDBC学习笔记(1)的更多相关文章

  1. JDBC 学习笔记(十一)—— JDBC 的事务支持

    1. 事务 在关系型数据库中,有一个很重要的概念,叫做事务(Transaction).它具有 ACID 四个特性: A(Atomicity):原子性,一个事务是一个不可分割的工作单位,事务中包括的诸操 ...

  2. JDBC 学习笔记(十)—— 使用 JDBC 搭建一个简易的 ORM 框架

    1. 数据映射 当我们获取到 ResultSet 之后,显然这个不是我们想要的数据结构. 数据库中的每一个表,在 Java 代码中,一定会有一个类与之对应,例如: package com.gerrar ...

  3. JDBC 学习笔记(六)—— PreparedStatement

    1. 引入 PreparedStatement PreparedStatement 通过 Connection.createPreparedStatement(String sql) 方法创建,主要用 ...

  4. JDBC学习笔记二

    JDBC学习笔记二 4.execute()方法执行SQL语句 execute几乎可以执行任何SQL语句,当execute执行过SQL语句之后会返回一个布尔类型的值,代表是否返回了ResultSet对象 ...

  5. JDBC学习笔记一

    JDBC学习笔记一 JDBC全称 Java Database Connectivity,即数据库连接,它是一种可以执行SQL语句的Java API. ODBC全称 Open Database Conn ...

  6. JDBC学习笔记(2)——Statement和ResultSet

    Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数据库连接的基础上,向数据库发送要执行的SQL语句.Statement ...

  7. JDBC学习笔记(1)——JDBC概述

    JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据库连接. JDBC库中所包含的API任务通常与数据库使用: 连接到数 ...

  8. 【转】JDBC学习笔记(2)——Statement和ResultSet

    转自:http://www.cnblogs.com/ysw-go/ Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数 ...

  9. 【转】JDBC学习笔记(1)——JDBC概述

    转自:http://www.cnblogs.com/ysw-go/ JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据 ...

随机推荐

  1. Quartus II中FPGA的管脚分配保存方法

    一.摘要 将Quartus II中FPGA管脚的分配及保存方法做一个汇总. 二.管脚分配方法 FPGA 的管脚分配,除了在QII软件中,选择“Assignments ->Pin”标签(或者点击按 ...

  2. js实现一套代码来控制所有的运动,图片的淡入淡出,winth,height的变宽

    介绍了那么多运动,這次一套代码实现所有运动 1.html代码和css代码,只是定义一个div <style> div{ width:200px; height:200px; margin: ...

  3. android menu的问题

    1.简单使用 @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.me ...

  4. PHP连接SQLServer

    连接前配置系统: 1.检查文件 php5.2.5/ntwdblib.dll 默认下面有一个,不能连接再替换. 下载正确版本的 ntwdblib.dll (2000.80.194.0),地址: http ...

  5. APPLICATION ERROR #1502 .

    mantisbt出现1502问题解决:引起问题的原因:当提交的问题有分类,此时删除此分类,就会出现下面的情况.问题描述:APPLICATION ERROR #1502 没有找到类别.请使用浏览器的“返 ...

  6. dedecms代码研究三

    上次,我们从dedecms的index.PHP文件中了解到了很多信息,也提出了一些问题: 1)加载了/include/common.inc.php,里面做了哪些工作? 2)/include/arc.p ...

  7. MVC 自定义IModelBinder实现json参数转Dictionary<string, string>

    IModelBinder的学习不算深入,现在用它来实现一个json转Dictionary<string, string> 一.原始json转Dictionary<string, st ...

  8. WinServer2008r2 机器时间格式修改

    windows2008 这么高级的系统不可能改个系统的日期时间显示格式还要进注册表啊.于是有baidu,google了下终于发现了,原来还有不需要注册表的更简便方法.windows2008默认时间格式 ...

  9. Inside The C++ Object Model - 02

    前言 - 什么是C++对象模型 C++对象模型包括2个方面的含义: 1.语言中直接支持面向对象程序设计的部分 2.对于各种(面向对象)支持的底层实现机制. 无论是什么语言,都需要转换为汇编.很多面向对 ...

  10. 误将文件push到Git,如何删除

    首先在本地删除多余文件夹(文件) 使用git add -u  git add -u,使用-u参数调用了git add命令,会将本地有改动(包括删除和修改)的已经追踪的文件标记到暂存区中.    再co ...