假设让你接触一样新的东西。你可能感觉无所适从,可是假设本来就是旧事物的话,你学习起来还难吗?

一、ODBC,我们的老朋友

ODBC(Open Database Connectivity)是微软公司与数据库的接口规范。

精华点:

1.ODBC,建立了一组规范并提供了一组对数据库訪问的标准API,标准应用程序数据接口。

2.ODBC是用C语言实现的,里面用到了大量的指针。

3.ODBC驱动程式的使用把应用程式从详细的数据库调用中隔离开来,驱动程式管理器针对特定数据库的各个驱动程式进行集中管理,并向应用程式提供统一的标准接口,

4.结构模型:分为四部分,应用程序接口,驱动器管理器,数据库驱动器和数据源。详细看图:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2Fvemhhbmd5aW5nZmVpMDEwOQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

二、JDBC。应呼声而起

JAVA语言的出现。风靡全球。当时JAVA人员用ODBC来操作数据库应用程序的时候。遇到了非常多的麻烦,比方ODBC是使用C语言实现的,而且包括大量的指针。这对JAVA全然面向对象的思想是一个非常大的冲突,导致了JAVA的非常多优秀特性无法使用,比方平台无关性。面向对象特性等。

于是。应呼声而起,SUN公司开发了一套专门java语言为接口的数据库应用程序开发接口。

JDBC(Java DataBase Connectivity)是Java与数据库的接口规范。

精华点:

1.JDBC定义了一个支持标准SQL功能的通用低层的应用程序编程接口(API)。

2.JDBC是用java语言实现的,全然面向对象的思想,具有平台无关性,一致性强。安全稳定。分布式。易用等长处,而且还扩展了java的能力。

3.JDBC是Java通过数据库驱动与数据库进行通信。利用Java的平台无关性,JDBC应用程式能自然地实现跨平台特性,因而更适合于internet上异构环境的数据库应用。(与ODBC一样)

4.结构模型:分为四部分。应用程序接口。驱动器管理器,数据库驱动器和数据源。

(与ODBC一样)详细看图:

三、对照来学习

同样点:

1.JDBC与ODBC都是基于X/Open的SQL调用级接口。

2.JDBC非常多设计思想沿袭了ODBC,包含很多抽象和SQL CLI实现。.ODBC与JDBC都提供对SQL语言的支持;

3.JDBC的整体结构类似于ODBC,如图:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2Fvemhhbmd5aW5nZmVpMDEwOQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

不同点:

1.ODBC是由微软公司。用C语言编写的,当中用到了大量的指针;JDBC是由SUN公司,用JAVA语言编写的。全然面向对象的思想。

2.ODBC难以学习,ODBC把简单功能和复杂功能混杂在一起,即便是简单的事情也会带来复杂的操作;JDBC易于学习,设计理念是简单的事情简单做。必要时才会让用户使用高级功能。

3.ODBC的驱动器管理程序和驱动器必须手工安装到每台客户机上。JDBC的驱动器因为全是用JAVA编写,所以JDBC能够在全部的JAVA平台上自己主动安装。

四、扩展和总结

扩展:

JDBC-ODBC,它出现的原因非常easy:我们有时候须要用JAVA语言连接微软的数据库,可是因为微软的数据库不是由JAVA编写的,所以我们须要一个桥连接。

详细的实现就不在这里提及了。可是有一点须要注意的是,JDBC是使用JAVA的数据库驱动直接和数据库相连,而JDBC-ODBC连接的是ODBC的数据源,真正与数据库建立连接的是ODBC。

总结

技术上该总结的都在比較中总结出来的,在这里仅仅想说明一点,我自己从一開始打算弄懂JDBC,然后又想到了ODBC,但是对于ODBC也仅限于用过,所以感觉非常乱,整理了几天之后,就发现,最可以让自己搞清关系的是“追本溯源”,从“根”上查起,这就有种知识网再生长。往外扩展或者更加密集的感觉。而不是突兀的出现一个点。让自己绞尽脑汁。生搬硬套的找关系,而是自然而然的。顺生长,感觉还是这种学习比較好,并且有效率。推荐给大家!

J2EE的13个规范之JDBC的更多相关文章

  1. (转)J2EE中13个规范

       今天在做连接oracle数据库的时候,感受到了什么是规范.平时听到别人说学习j2ee一定要学习他的十三个规范,大概的知道每个规范是做什么的,每个“接口”是做什么的.          很早就听过 ...

  2. J2EE的13个规范总结

    转载自:http://blog.csdn.net/zhuanzhe117/article/details/38763483 什么是J2EE? 在企业级应用中,都有一些通用企业需求模块,如数据库连接,邮 ...

  3. 【java 理论篇 2】J2EE的13种规范

    导读:看完了J2EE的视频,没有什么技术实践,现在就从理论上说明一下J2EE的13种规范,以及现在的自己对它的一个理解.可能会有偏差,但是,算是做为目前的一个记录. 一.13种规范 1.1.JDBC( ...

  4. J2EE之13个规范标准概念

    主要是关于j2EE十三个规范的总结. java基础知识 首先java分为三类:J2ME.J2SE.J2EE. 依据开发软件的大小和量级他们的作用分别不同,J2ME是开发为机顶盒.移动电话和PDA之类嵌 ...

  5. J2EE的13个规范之(二) JDBC 及其使用

    我想大家都知道ODBC是什么?ODBC(OpenDatabaseConnectivity.开放数据库互连)是微软公司开放服务结构(WOSA,WindowsOpenServicesArchitectur ...

  6. J2ee的13个规范

    以下来自于网络. 1.JDBC(java Database Connectivity): JDBC API为访问不同的数据库提供了一种统一的途径,就像ODBC一样,JDBC对开发者屏蔽了一些细节问题, ...

  7. J2EE的13种规范

    1.JDBC(Java Databaes Connectivity):JDBC API为访问不同的数据库提供了一种统一的途径,就像ODBC一样,JDBC对开发者屏蔽了一些细节问题,同时,JDBC对数据 ...

  8. J2EE的13个规范之(三) Servlet简单介绍

    Servlet是一种server端脚本,它是一个特殊的Java类,继承自HttpServlet.开发中主要用于处理和响应client的请求. Servlet在容器中执行,事实上例的和销毁创建由容器进行 ...

  9. j2ee的十三个规范

    转载 今天在做连接oracle数据库的时候,感受到了什么是规范.平时听到别人说学习j2ee一定要学习他的十三个规范,大概的知道每个规范是做什么的,每个“接口”是做什么的.          很早就听过 ...

随机推荐

  1. memory引擎的索引失效一例

    memory引擎的索引失效一例 memory引擎的索引失效一例

  2. 移植一个开源点餐网到SAE平台上

    记得以前我准备弄个点餐网的,但是由于一些原因没有做下去. 前几天将网上的一个点餐源码移植到了SAE上,网址http://diancan4sae.sinaapp.com. 我想做个外卖网,先选一个学校周 ...

  3. 百度搜索结果页url参数详解

    在百度首页输入任意关键词搜索之后,我们跳转到搜索结果页面,在浏览器的网址栏我们可以看到很长的一串url地址.那么,你真的了解这一串url的含义吗? s?:搜索 百度搜索结果页使用了重定向,因此我们看到 ...

  4. 14.4.3.4 Configuring InnoDB Buffer Pool Prefetching (Read-Ahead) 配置InnoDB Buffer pool 预读

    14.4.3.4 Configuring InnoDB Buffer Pool Prefetching (Read-Ahead) 配置InnoDB Buffer pool 预读 一个预读请求 是一个I ...

  5. 轻松学会多线程(四)——synchronized同步keyword知多少

    每个对象都有一把独占锁. 独占锁仅仅限制线程对它的同步方法的訪问,对非同步方法,独占锁没有意义. synchronizedkeyword能够作为函数的修饰符,也能够作为函数内的语句,也就是平时说的同步 ...

  6. DMA过程分析

    1.1 当我们在应用程序中编写write系统调用,向磁盘中写入数据时,写入请求会先调用底层写函数,将请求先写入内存中的页快速缓存(page cache)中,写入成功则立马返回,真正的写入磁盘操作会延迟 ...

  7. ThinkPHP多应用/项目配置技巧(使用同一配置文件)--(十六)

    原文:ThinkPHP多应用/项目配置技巧(使用同一配置文件)--(十六) ThinkPHP多应用配置技巧(没有使用分组,这是通过入口文件产生的Home.Admin)----很实用! 比如:现在有Ho ...

  8. [Cocos2d-x]解决Android平台ndk-build时不自动删除外部库

    参考链接: http://blog.chinaunix.net/uid-26009923-id-3430612.html http://hi.baidu.com/hpyfei/item/52a2b21 ...

  9. MySQLdb的安装与使用

    一.安装 安装已编译版本号(此方法简便快捷): http://www.codegood.com/downloads 依据自己系统下载,双击安装,搞定 然后import MySQLdb.查看是否成功 我 ...

  10. Java-WebSocket 项目的研究(三) WebSocketClient 类 具体解释

    通过之前两篇文章 Java-WebSocket 项目的研究(一) Java-WebSocket类图描写叙述 Java-WebSocket 项目的研究(二) 小试身手:client连接server并发送 ...