JDBC——入门知识【转】
1. 什么是JDBC:Java数据库连接性(JavaDatabase Connectivity) API,允许用户从Java应用程序中访问任何表格化数据源。
2. JDBC除了提供到更宽范围的SQL数据库的连接外,也允许用户访问其他的表格数据源,如:电子表格。
3. JDBC定义了一个底层的API,用来支持独立于任何特定SQL实现的基本SQL功能。这意味着重要的是执行原SQL语句,然后检索它们的结果。
4. JDBC2.0 API包括两个包:java.sql和jvax.sql。
5. JDBC3.0规范,于2001年10月发布,引入几个特性,包括支持各种数据类型,附加的元数据能力,并增加了大量的接口。
6. JDBC的三种主要功能如下:
- 建立与数据库或其他表列数据源的连接;
- 向数据库发送SQL命令
- 处理结果
7. 使用JDBC API访问数据库,并处理结果集的主要步骤:
- 装载JDBC驱动程序
- 获取数据库连接
- 创建一条语句,执行SQL环境(Statement)
- 执行SQL查询
- 从ResultSet中检索数据
- 释放资源
8. 装载JDBC驱动程序的几种方式:
- Class.forName("驱动类的全限定名");
- Driver d = new 驱动类全限定名();
DriverManager.registerDriver(d); // 可以省略此句 - java -Djdbc.drivers = 驱动类全限定名
此种方式是在启动JVM时就将驱动类加载进Java虚拟机
9. 获取数据库连接
Connection conn = DriverManager.getConnection( url, user, password );
10. 创建执行SQL环境
Statement stmt = conn.createStatement();
11. 执行SQL
String sql = "select rownum, sysdate from dual";
ResultSet rs = stmt.executeQuery(sql);
12. 处理结果集
while(rs.next()) {
int i = rs.getInt(1);
Date d = rs.getDate(2);
System.out.println(i + " , " + d);
}
// 注意,JDBC结果集列是从“1”开始的,而其它地方如hibernate等都是从“0”开始的
13. 释放资源
if(rs != null) rs.close();
if(stmt != null) stmt.close();
if(conn != null) conn.close();
14. 常见的几种数据库连接方式:
- Oracle数据库:
Class.forName("oracle.jdbc.driver.OracleDriver");
String url = "jdbc:oracle:thin:@[hostName]:[port]:[DB]"; - MySQL数据库:
Class.forName("");
String url = "jdbc:mysql://[hostName]:[port]/[DB]";
15. JDBC驱动程序类型(4种)
- JDBC-ODBC桥 + ODBC驱动程序
优点:
它提供连接几乎所有平台上的所有数据库能力;
它可能是访问低端桌面数据库和应用程序的唯一方式。
缺点:
ODBC驱动程序也必须加载到目标机上;
JDBC和ODBC转换影响性能。 - 本地API部分Java驱动程序
优点:
比前一种驱动程序快得多
缺点:
需要在目标机上有本地代码;
它们依赖的Java本地接口在不同JVM的提供商间的实现不一致。 - JDBC-Net纯Java驱动程序
优点:
不要求客户上有任何本地二进制代码;
不需要客户安装;
支持多个网络选项。
缺点:
由于网络接口将体系结构复杂化,因此很难建立。 - 本地协议纯Java驱动程序
目前的驱动程序都是使用这种,比JDBC-ODBC桥快得多,100%Java驱动程序,本地协议。
JDBC——入门知识【转】的更多相关文章
- Jdbc入门
JDBC入门 l 导jar包:驱动! l 加载驱动类:Class.forName(“类名”); l 给出url.username.password,其中url背下来! l 使用DriverMa ...
- [置顶] Mysql存储过程入门知识
Mysql存储过程入门知识 #1,查看数据库所有的存储过程名 #--这个语句被用来移除一个存储程序.不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程 #SELECT NAME FROM ...
- 移动H5开发入门知识,CSS的单位汇总与用法
说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着手机的流行,web app和hybrid a ...
- H5移动端开发入门知识以及CSS的单位汇总与用法
说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着手机的流行,web app和hybrid a ...
- Java web 入门知识 及HTTP协议详解
Java web 入门知识 及HTTP协议详解 WEB入门 WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. Internet上供外界访问的Web资 ...
- Java基础入门知识
Java编程入门知识 知识概要: (1)Java入门基本常识 (2)Java的特性跨平台性 (3)Java的编程环境的搭建 (4)Java的运行机制 (5)第一个Java小程序入门 (1)Java ...
- zabbix入门知识
zabbix入门知识 zabbix中文手册 https://www.zabbix.com/documentation/3.4/manual/ 1.zabbix介绍 Zabbix 是一个企业级的分布式开 ...
- React的入门知识与概念【1】
回顾在以往的项目开发中,从最初的使用的原生html+js+css+jquery开发,到后来随着项目功能的增加,也渐渐学习了Vue.js框架的开发,以及Vue.js的全家桶Axios,Vue-route ...
- 我的Python笔记补充:入门知识拾遗
声明:本文整理借鉴金角大王的Python之路,Day1 - Python基础1,仅供本人学习使用!!! 入门知识拾遗 一.bytes类型 二.三元运算 1 result = 值1 if 条件 else ...
随机推荐
- 处理TCP连包的一小段代码
学习网络编程也有一段时间了,一直听说TCP数据会连包,但一直不知道怎么测试好.最近测试了下:发送方使用对列,将发送的数据存入队列,然后开线程,专门发送.发送多包数据之间不延时.在接收方,他们确实连在一 ...
- linux命令启动服务(tomcat服务或者jar包)
启动tomcat: 1.方式一:直接启动 ./startup.sh 2.方式二:nohup ./startup.sh & 启动后,关闭当前客户端连接,重新启动一个查看是 否已经启动 启动jar ...
- linux网络配置及IP绑定
在学习时,参考了这篇文章:http://blog.csdn.net/collection4u/article/details/14127671:在这篇文章中作者讲述了VMware中虚机的三种网络模式: ...
- C语言一个单链表的实现
-- 所谓链表记住一句即可:地址不连续,大家只是握个手而已: list0.c #include<stdio.h> #include<malloc.h> typedef int ...
- WebSocket使用教程 - 带完整实例--网址:https://my.oschina.net/u/1266171/blog/357488
什么是WebSocket?看过html5的同学都知道,WebSocket protocol 是HTML5一种新的协议.它是实现了浏览器与服务器全双工通信(full-duplex).HTML5定义了We ...
- codeforces 669E E. Little Artem and Time Machine(节点为map型的线段树)
题目链接: E. Little Artem and Time Machine time limit per test 2 seconds memory limit per test 256 megab ...
- POJ2976:Dropping tests(01分数规划入门)
In a certain course, you take n tests. If you get ai out of bi questions correct on test i, your cum ...
- 替换一个文件中的内容BAT
@echo off setlocal enabledelayedexpansion set file=%1set "file=%file:"=%" for %%i in ...
- mac上python3安装HTMLTestRunner
下载支持python3版本的HTMLTestRunner.py文件后,拷贝到python3的lib目录下 在终端输入如下命令: 将HTMLTestRunner.py文件拷贝到如下目录后,pycharm ...
- Flink架构及其工作原理
目录 System Architecture Data Transfer in Flink Event Time Processing State Management Checkpoints, Sa ...