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驱动程序,本地协议。
时间: 2024-10-10 15:32:37

JDBC——入门知识【转】的相关文章

01.JDBC入门

一.JDBC入门 1.JDBC简介 JDBC, 即Java Database Connectivity,JDBC 为工具/数据库开发人员提供了一个标准的 API,使他们能够用纯Java API 来编写数据库应用程序.即Java数据库编程接口,是一组标准的Java语言中的接口和类,使用这些接口和类,Java客户端程序可以访问各种不同类型的数据库,比如建立数据库连接.执行SQL语句进行数据的存取操作. JDBC规范采用接口和实现分离的思想设计了Java数据库编程的框架.接口包含在java.sql及j

ESB (Enterprise Service Bus)入门知识

本文主要介绍ESB相关的一些技术概念与术语,还有一些入门的需要了解的基础知识,并初步了解介绍一些ESB产品.由于本人刚接触ESB,所以将自己的学习内容与过程,记录下来!愿在这里与大家分享一下,共同进步与提高! [转载使用,请注明出处:http://blog.csdn.net/mahoking] EAI 企业应用集成(Enterprise Application Integration):是完成在组织内.外的各种异构系统.应用和数据源之间共享.交换信息.协作的途径,方法学,标准和技术. 所连接的应

21、jdbc入门1

jdbc入门 什么是jdbc 使用java代码(程序)发送sql语句的技术,就是jdbc技术!!!! 连接案例 /** * jdbc连接数据库 * @author APPle * */ public class Demo1 { //连接数据库的URL private String url = "jdbc:mysql://localhost:3306/day17"; // jdbc协议:数据库子协议:主机:端口/连接的数据库 // private String user = "

JDBC 基础知识总结

1.  何谓JDBC  --- Java Database Connectivity. 由Sun 公司提供的访问数据库的一组java类和接口,用来对数据库进行链接.发送SQL语句.处理返回结果,为开发人员提供了统一的访问数据库入口API,使得开发人员可以不用绑定到特定数据库访问API. 2. 应用程序,JDBC API,JDBC 驱动程序,数据库之间的层次关系如下图: 3. 4.  JDBC 有四种驱动: 4.1  JDBC-ODBC 桥链接:   把对JDBC接口的访问翻译成对应的ODBC的访

Spring JDBC入门

Spring将替我们完成所有使用JDBC API进行开发的单调乏味的.底层细节处理工作. 操作JDBC时Spring可以帮我们做这些事情: 定义数据库连接参数,打开数据库连接,处理异常,关闭数据库连接 我们仅需要关注: 声明SQL语句,处理每一次得到的结果 一个较为简单的例子与讲解 JdbcTemplate类 JdbcTemplate是core包的核心类.它替我们完成了资源的创建以及释放工作,从而简化了我们对JDBC的使用.它还可以帮助我们避免一些常见的错误,比如忘记关闭数据库连接.JdbcTe

债券入门知识

可参考此链接: http://www.jisilu.cn/topic/%E4%BC%81%E4%B8%9A%E5%80%BA%E6%85%A2%E8%B0%88 国债: 凭证式国债: 国家采取不印刷实物券,而用填制国库券收款凭证的方式发行的国债.它是以国债收款凭单的形式来作为债权证明,不可上市流通转让,从购买之日起计息.在持有期内,持券人如遇特殊情况需要握取现金,可以到购买网点提前兑取.提前兑取时,除偿还本金外,利息按实际持有天数及相应的利率档次计算.凭证式国债在银行柜台凭身份证购买,与银行定期

基金入门知识

1. 基金是什么? 基金就是代大家理财的一个产品.比如股票型基金,就是把大家的钱收集起来,由买股经验丰富的基金经理帮大家买股票. 2. 基金产品靠什么挣钱? 基金依靠用户买入和赎回基金份额时的手续费,还有交纳的管理费等挣钱.如果某基金经理非常牛B,给投资人带来了丰厚的回报,那么买这支产品的人就越来越多,这样基金产品就越来越赚钱.相反,如果基金产品投资管理不善,给投资人带来了损失,那么买这支产品的人就是越来越少,可用于投资的钱就是越来越少,进一步削弱提高收益的可能性.基金产品并不直接从投资行为中挣

移动H5开发入门知识,CSS的单位汇总与用法

说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着手机的流行,web app和hybrid app的开发,都用到了css3技术,在css3中,新增了许多单位,rem.vw和vh.vmin和vmax.ch和ex等等,那现在对这些单位分别做一下详细的介绍吧. 1.em 做前端的应该对em不陌生,不是什么罕见的单位,是相对单位,参考物是父元素的font-size,具有继承的特点.如果字体大小是16

requirejs入门知识整理

使用模块化开发处理的三大问题: 1.命名冲突:2.繁琐的文件依赖 3.实现异步非阻塞的文件加载,避免网页失去响应 模块化的设计使得JavaScript代码在需要访问“全局变量”的时候,都可以通过依赖关系,把这些“全局变量”作为参数传递到模块的实现体里,在实现中就避免了访问或者声明全局的变量或者函数,有效的避免大量而且复杂的命名空间管理. requirejs以一个相对于baseUrl的地址来加载所有的代码.如果用了data-main属性,则该路径就是baseUrl,baseUrl亦可通过requi