JDBC学习笔记(1)
说明:本系列学习笔记主要是学习传智播客的李勇老师的教学课程和一本英文电子书《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)的更多相关文章
- JDBC 学习笔记(十一)—— JDBC 的事务支持
1. 事务 在关系型数据库中,有一个很重要的概念,叫做事务(Transaction).它具有 ACID 四个特性: A(Atomicity):原子性,一个事务是一个不可分割的工作单位,事务中包括的诸操 ...
- JDBC 学习笔记(十)—— 使用 JDBC 搭建一个简易的 ORM 框架
1. 数据映射 当我们获取到 ResultSet 之后,显然这个不是我们想要的数据结构. 数据库中的每一个表,在 Java 代码中,一定会有一个类与之对应,例如: package com.gerrar ...
- JDBC 学习笔记(六)—— PreparedStatement
1. 引入 PreparedStatement PreparedStatement 通过 Connection.createPreparedStatement(String sql) 方法创建,主要用 ...
- JDBC学习笔记二
JDBC学习笔记二 4.execute()方法执行SQL语句 execute几乎可以执行任何SQL语句,当execute执行过SQL语句之后会返回一个布尔类型的值,代表是否返回了ResultSet对象 ...
- JDBC学习笔记一
JDBC学习笔记一 JDBC全称 Java Database Connectivity,即数据库连接,它是一种可以执行SQL语句的Java API. ODBC全称 Open Database Conn ...
- JDBC学习笔记(2)——Statement和ResultSet
Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数据库连接的基础上,向数据库发送要执行的SQL语句.Statement ...
- JDBC学习笔记(1)——JDBC概述
JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据库连接. JDBC库中所包含的API任务通常与数据库使用: 连接到数 ...
- 【转】JDBC学习笔记(2)——Statement和ResultSet
转自:http://www.cnblogs.com/ysw-go/ Statement执行更新操作 Statement:Statement 是 Java 执行数据库操作的一个重要方法,用于在已经建立数 ...
- 【转】JDBC学习笔记(1)——JDBC概述
转自:http://www.cnblogs.com/ysw-go/ JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据 ...
随机推荐
- 如何修改SharePoint列表条数等阈值
若要修改SharePoint中对列表最大条数等设定的阈值,可按如下步骤操作: 1. 打开页面:管理中心 > 应用程序管理 > 管理Web应用程序.2. 选择要修改阈值的Web应用程序,并在 ...
- Spark SQL External Data Sources JDBC简易实现
在spark1.2版本中最令我期待的功能是External Data Sources,通过该API可以直接将External Data Sources注册成一个临时表,该表可以和已经存在的表等通过sq ...
- 用通俗易懂的大白话讲解Map/Reduce原理
Hadoop简介 Hadoop就是一个实现了Google云计算系统的开源系统,包括并行计算模型Map/Reduce,分布式文件系统HDFS,以及分布式数据库Hbase,同时Hadoop的相关项目也很丰 ...
- Libevent 定时器
先摘一点网上的介绍 libevent是一个事件触发的网络库,适用于windows.linux.bsd等多种平台,内部使用select.epoll.kqueue等系统调用管理事件机制.著名分布式缓存软件 ...
- xml 中转意字符&\/使用方法
所有 XML 元素都须有关闭标签 在 HTML,经常会看到没有关闭标签的元素: <p>This is a paragraph <p>This is another paragr ...
- Device Path in WinPrefetchView
As we know that the Prefetch file is used for optimizing the loading time of the application in the ...
- 【转】java的socket编程
转自:http://www.cnblogs.com/linzheng/archive/2011/01/23/1942328.html 一,网络编程中两个主要的问题 一个是如何准确的定位网络上一台或多台 ...
- Selenium+Python+Eclipse网页自动化集成环境配置(附简单的测试程序)
最近公司在给我们培训,主要是网页自动化测试的,现在的工作每天都是测APP,刚刚入门,不过,当我看了别人写的bug之后,就觉得不会觉得能够发现bug多么多么的厉害了. 前两周的时间一直在搭建自动化测试的 ...
- oracle replace函数
replace 函数用法如下: replace('将要更改的字符串','被替换掉的字符串','替换字符串') 例如: select t.dqsj,replace(t.dqsj,'16:40','16: ...
- MS SQL Server之光标、存储过程和触发器
光标 通常数据库操作被认为是以数据集为基础的操作,但是光标被用于以记录为单位来进行操作,来获取数据库中的数据的子集.光标一般用于过程化程序里的嵌入的SQL语句. 对光标的定义如下: DECLARE C ...