JDBC 具体解释(1)

        在以java application server应用为主的平台是,JDBC的最高级应用是DataSource的实现,其他的JDO,webcache,hibernate等只是是一种封装,所以看数据库应用的性能,主要看据库连结的利用率,所以,DataSource能够说是J2EE最最重要的应用.

对于主流的数据库,如mysql,ms sqlserver,oracle,从其通用的性能来看,建议在JAVA平台上应用oracle和mysql,ms sqlserver的数据库在JAVA平台上的性能仅仅能达到上述两种数据库的60-70%,在相同硬件的基础是,做相同的操作,測试了这三种数据库对并发的支持,MYSQL最高为430,ORACLE为400,SQLSERVER仅仅有250.

假设你不得不用SQLSERVER作为JAVA平台的数据库,那么一个合适的JDBC是最最重要的,ms sqlserver自己提供的JDBC到眼下为止并不能真正支持DataSource,只是bea的weblogic8中已经内置了type4的ms sqlserver的JDBC,这是一个真正支持DataSource的JDBC,假设你不得不用sqlserver,你能够把这个JDBC从BEA的WLS中驳离出来.

另外一点,假设你的J2EE应用主要集中在jsp/servlet,而后台数据库採用oracle的话,那么你有福了.你不要採用其他的WEB容器,在oracle8.17以后的版本号中都内置了servlet引擎.假设你基于这个引擎,你会获得其他应用组合所无法比拟的性能,由于ORACLE的WEB容器是工作在数据库的地址空间,这就意味着,容器对数据库的訪问是"本地文件存取方式",

尽管oracle也提供了标准的JDBC接口让调用者调用,但其实这时的Connection对象仅仅相当于一个文件句柄,而其他的JDBC连结都是封装了Socket,通过Socket和数据库进行通讯,假设你不理解这里的差别,那我打一个例如:就好象两个人面对面谈话和通过国际长途谈话的差别,这其间的性能怎一个高字了得.

mysql从来就是被设计为"网络数据库",针对数据安全性不是太重要的应用.它的最大长处是通用,性能高,速度快,安全性较低,对于不是机密要件的应用,用MYSQL肯定没错.

        MS SQLSERVER,除了在JAVA平台上性能表现不好外,没有什么可说的,假设换在WIN平台上,它是顶级首选项,没有不论什么数据库在WIN平台上能够和它做不论什么方面的比較.

        ORACLE,JAVA平台上的老大,除去成本因素,在JAVA平台上没有理由不选择它. 



JDBC,JAVA平台的DATABASE的连通性.就是JAVA平台上和数据库进行连结的"工具".



接口:从下向上,接口是对"案例"的抽象,由一个案例抽象出一些规则.

         从上向下,被抽象出来的接口是对案例的一种承诺和约束.

也就是说,仅仅要你实现我规定的接口,你的类就已经具有了接口对外承诺的方法,仅仅要"客户"会操作接口,不须要又一次学习就会操作实现了该接口的新类!

        1.通过接口能够实现不相关的类的同样行为. 

        2.通过接口能够指明多个类须要实现的方法.

        3.通过接口能够了解对象的交互方法而不须要了解对象所相应的类蓝本.



为了通用,JAVA中要求有一种机制,在操作不同厂商数据库时有同样的方法去操作,而不是每接触一种数据库就要学习新的方法.完毕这样的机制的"东西"就叫"JDBC"了.

简单地分,JDBC有两部分组成,JDBC API和JDBC Driver Interface.

JDBC API就是提供给"客户"的一组独立于数据库的API,对不论什么数据库的操作,都能够用这组API来进行.那么要把这些通用的API翻译成特定数据库能懂的"指令",就要由JDBC Driver Interface来实现了,所以这部分是面向JDBC驱动程序开发商的编程接口,它会把我们通过JDBC API发给数据库的通用指令翻译给他们自己的数据库.



还是通过实际操作来看看JDBC怎样工作的吧.



由于JDBC API是通用接口,那么程序是怎样知道我要连结的是哪种数据库呢?所以在和数据库连结时先要载入(或注冊可用的Driver),事实上就是JDBC签名.载入驱动程序和好多方法,最经常使用的就是先把驱动程序类溶解到内存中,作为"当前"驱动程序.注意"当前"是说内存中能够有多个驱动程序,但仅仅有如今载入的这个作为首选连结的驱动程序.

Class.forName("org.gjt.mm.mysql.Driver");

Class.forName方法是先在内存中溶解签名为"org.gjt.mm.mysql.Driver"的Driver类,Driver类就会把相应的实现类相应到JDBC API的接口中.

比方把org.gjt.mm.mysql.Connection的实例对象赋给java.sql.Connection接口句柄,以便"客户"能通过操作java.sql.Connection句柄来调用实际的org.gjt.mm.mysql.Connection中的方法.至于它们是假设映射的,这是厂商编程的,"客户"仅仅要调用Class.forName("org.gjt.mm.mysql.Driver");方法就能够顺利地操作JDBC API了.



一个普通数据库的连结过程为:

        1.载入驱动程序.

        2.通过DriverManager到得一个与数据库连结的句柄.

        3.通过连结句柄绑定要运行的语句.

        4.接收运行结果.

5.可选的对结果的处理.

6.必要的关闭和数据库的连结.

JDBC 具体解释(1)的更多相关文章

  1. JDBC具体解释(2)

    1.载入驱动程序. 注冊驱动程序有多方法,Class.forName();是一种显式地载入.当一个驱动程序类被Classloader装载后,在溶解的过程中,DriverManager会注冊这个驱动类的 ...

  2. 69 个经典 Spring 面试题和答案

    Spring 概述 什么是spring?Spring 是个java企业级应用的开源开发框架.Spring主要用来开发Java应用,但是有些扩展是针对构建J2EE平台的web应用.Spring 框架目标 ...

  3. Oozie

    Oozie的功能模块 workflow 由多个工作单元组成 工作单元之间有依赖关系 MR1->MR2->MR3->result hadoop jar:提交1个MR oozie:监控当 ...

  4. Hadoop生态圈-Oozie部署实战

    Hadoop生态圈-Oozie部署实战 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Oozie简介 1>.什么是Oozie Oozie英文翻译为:驯象人.一个基于工作流 ...

  5. 大数据技术之_14_Oozie学习_Oozie 的简介+Oozie 的功能模块介绍+Oozie 的部署+Oozie 的使用案列

    第1章 Oozie 的简介第2章 Oozie 的功能模块介绍2.1 模块2.2 常用节点第3章 Oozie 的部署3.1 部署 Hadoop(CDH版本的)3.1.1 解压缩 CDH 版本的 hado ...

  6. BATJ面试必会之 Spring 篇(一)

    译者:深海 校对:方腾飞 出自并发编程网 – ifeve.com 目录 Spring 概述 依赖注入 Spring beans Spring注解 Spring数据访问 Spring面向切面编程(AOP ...

  7. 《JSP+Servlet+Tomcat应用开发从零開始学》

    当当网页面:  http://product.dangdang.com/23619990.html 内容简单介绍      本书全面介绍了 JSP开发中涉及的相关技术要点和实战技巧. 全书结构清晰,难 ...

  8. 大数据技术之Oozie

      第1章 Oozie简介 Oozie英文翻译为:驯象人.一个基于工作流引擎的开源框架,由Cloudera公司贡献给Apache,提供对Hadoop MapReduce.Pig Jobs的任务调度与协 ...

  9. MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

随机推荐

  1. js设计模式-适配器模式

    说明:适配器模式表面上看起来像门面模式.它们都要对别的对象进行包装并改变其呈现的接口.但是两者的差别在于它们如何改变接口.门面元素展现的是一个简化的接口,它并不提供额外的选择,而且有时为了方便完成常见 ...

  2. SwiftUI 官方教程(三)

    3. 用 Stacks 组合 View 在上一节创建标题 view 后,我们来添加 text view,它用来显示地标的详细信息,比如公园的名称和所在的州. 在创建 SwiftUI view 时,我们 ...

  3. 一个 passive 引发的bug

    不是什么很难的东西,权且做个记录. 首先说下背景,目前的项目中,需要同时绑定 wheel 和 scroll 事件. 绑定 wheel,目的是开发 ctrl + wheel 缩放页面功能,此功能与浏览器 ...

  4. Blender Python UV 学习

    Blender Python UV 学习 1. bmesh面转换 bm = bmesh.from_edit_mesh(bpy.context.edit_object.data) bm.faces.en ...

  5. [lua] future模式*协程

    以下是lua实现的future模式.基于cocos客户端 local function param_pack( params, callback ) table.insert(params, call ...

  6. [Offer收割]编程练习赛35

    有歧义的号码 #include<stdio.h> #include<string.h> #include<stdlib.h> int cmp(const void ...

  7. JS学习笔记(一)JS处理JSON数据

    [摘抄]将JSON字符串转换为json对象的方法.在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键.例如:J ...

  8. 最影响APP软件质量和成本的三个方面。希望大家一定要记在心里!

    1.功能的开发方式 现在市场上存在的几种开发方式如下: a.web网页加壳生成APP web网页加壳生成APP的开发方式,先花几百块钱买个现成的手机网站模板,在加壳打包一个APP只需要5分钟,但是做出 ...

  9. H5 微信公众号 监听返回事件

    /*-----监听返回事件-----*/ function pushHistory(returnUrl,currentUrl,currentTitle) { window.addEventListen ...

  10. RedHat/centOS 部分字符处理

    sed -i '/^$/d' filename #删除空行sed -i '/tablename/d' filename #删除含有匹配字符串的行sed -i '/_c1/d' filename #删除 ...