JDBC 学习笔记(一)—— JDBC 基础
1. 什么是 JDBC
JDBC,Java Database Connectivity(Java 数据库连接),是一组执行 SQL 语句的 Java API。
JDBC,是 Java SE(Java Platform, Standard Edition)标准的一部分。
Java 程序可以通过 JDBC 连接到关系型数据库,并且使用 SQL(Structured Query Language,结构化查询语言)完成对数据库的操作。
我们开发时常用的 ORM 框架(Object Relational Mapping),例如 Hibernate,MyBatis,其本质就是对 JDBC 的一种封装。
2. JDBC 驱动和面向接口编程
Java API,就是接口(interface),所以说 JDBC 只给出了接口,没有提供实现类。
由各个数据库的厂商提供 JDBC 的实现,这些实现类就是我们口中常说的:驱动程序。
JDBC 的编程工作,是需要面向标准的 JDBC API,不需要关心使用的数据库到底是什么。
使用 Oracle,DB2,还是 MyBatis 对于 JDBC 的编程都没有影响,这就是面向接口编程。
理论上说,如果需要切换数据库,只需要换一个驱动程序就可以了,所以说,JDBC 具有跨数据库的特性。
当然实际操作上没有这么简单,因为 JDBC 跨数据库的特性是基于全部使用标准的 SQL 语句,而某些数据库会有一些只有自己才能用的特殊 SQL 语法。
例如,Oracle 的 rowid、rownum,MySQL 的 limit。
3. JDBC 组成和功能
JDBC的总体结构有四个组件:应用程序、驱动程序管理器、驱动程序和数据源。

JDBC 主要有以下三个功能:
- 建立程序与数据库的连接。
- 执行 SQL 语句。
- 获得 SQL 语句的执行结果。
4. JDBC 和 ODBC
ODBC,Open Database Connectivity(开放数据库连接),也是一组通过 API 访问数据库的技术。
ODBC 先于 JDBC 的出现,JDBC 模仿了 ODBC 的设计。
与 JDBC 相同,ODBC 需要数据库厂商提供驱动,支持数据库之间的切换,而 ODBC 负责管理数据库驱动。
相比于 ODBC,JDBC 有以下优势:
- JDBC 对于数据库的操作更加简单、直观。
- JDBC 具有更高的安全性。
JDBC 学习笔记(一)—— JDBC 基础的更多相关文章
- JDBC学习笔记(1)——JDBC概述
JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据库连接. JDBC库中所包含的API任务通常与数据库使用: 连接到数 ...
- 【转】JDBC学习笔记(1)——JDBC概述
转自:http://www.cnblogs.com/ysw-go/ JDBC JDBC API是一个Java API,可以访问任何类型表列数据,特别是存储在关系数据库中的数据.JDBC代表Java数据 ...
- JDBC学习笔记之JDBC简介
1. 引言 JDBC API是一种Java API,可以访问任何类型的表格数据,特别是存储在关系数据库中的数据. JDBC可以帮助我们编写下列三种编程活动的java应用程序: 1.连接到数据源,如数据 ...
- JDBC学习笔记一
JDBC学习笔记一 JDBC全称 Java Database Connectivity,即数据库连接,它是一种可以执行SQL语句的Java API. ODBC全称 Open Database Conn ...
- 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对象 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Java学习笔记:语言基础
Java学习笔记:语言基础 2014-1-31 最近开始学习Java,目的倒不在于想深入的掌握Java开发,而是想了解Java的基本语法,可以阅读Java源代码,从而拓展一些知识面.同时为学习An ...
随机推荐
- ansys-表格
转自http://blog.sina.com.cn/s/blog_833dee820102xwb3.html ANSYS中表格数组的定义及使用举例 ANSYS中会有许多的参数数据,这些参数的形成后要放 ...
- UVA 10954 Add All 全部相加 (Huffman编码)
题意:给你n个数的集合,每次选两个删除,把它们的和放回集合,直到集合的数只剩下一个,每次操作的开销是那两个数的和,求最小开销. Huffman编码.Huffman编码对于着一颗二叉树,这里的数对应着单 ...
- Android(java)学习笔记113:Activity的生命周期
1.首先来一张生命周期的总图: onCreate():创建Acitivity界面 onStart():让上面创建的界面可见 onResume():让上面创建的界面 ...
- Adobe登陆出现Access denied解决方法
当我安装好Adobe Acrobat Reader DC时,想要登陆Adobe账号时被Access denied. 一般说需要梯子,然而本人亲测这种方法不行(香港主机,全局模式下). 一个简单有效的方 ...
- 队列的add与offer的区别
两个方法都表示往队列里添加元素 但是当出现异常时,add方法抛出异常 而offer则返回的是false,就是啥事也没有,也不抛异常,也没有添加成功!
- python 嵌套作用域 闭包函数
#闭包函数 def multiplier(factor): def multiplyByFactory(number): return number*factor return multiplyByF ...
- javaweb基础(12)_session详解
一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...
- jdk配置与环境变量配置
1.1.下载jdk1.8.0,如图所示 解压放在你用的位置 在官网中下载 1.2.配置环境变量 打开环境变量:计算机-->属性-->高级系统配置-->环境变量 配置JAVA_HOME ...
- 【转】PCA for opencv
对于PCA,一直都是有个概念,没有实际使用过,今天终于实际使用了一把,发现PCA还是挺神奇的. 在OPENCV中使用PCA非常简单,只要几条语句就可以了. 1.初始化数据 //每一行表示一个样本 Cv ...
- sql_autoload_register()函数
复习__autoload的时候,看到了spl_autoload_register()这个函数.但是一下子没有弄明白,通过查资料我算是弄明白了. 1.__autoload() —— 自动加载 ...