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. bzoj4034: [HAOI2015]树上操作(树剖)

    4034: [HAOI2015]树上操作 题目:传送门 题解: 树剖裸题: 麻烦一点的就只有子树修改(其实一点也不),因为子树编号连续啊,直接改段(记录编号最小和最大) 开个long long 水模版 ...

  2. C# Log4Net简单使用方法

    log4net库是Apache log4j框架在Microsoft .NET平台的实现,是一个帮助程序员将日志信息输出到各种目标(控制台.文件.数据库等)的工具. 使用log4net,一个很明显的好处 ...

  3. nRF52832添加微信硬件接入服务AirSync

    开发环境 SDK版本:nRF5_SDK_15.0.0 芯片:nRF52832-QFAA OS: FreeRTOS 10.0.0 测试APP:AirSyncDebugger  https://iot.w ...

  4. website robots.txt 防爬虫 措施

    robots.txt文件用法举例: 1. 允许所有的robot访问 User-agent: * Allow: / 或者 User-agent: * Disallow: 2. 禁止所有搜索引擎访问网站的 ...

  5. django URL多层路由

    一.多层路由 如果django里的app数量越来越多,那项目里的urls文件配置起来将会很麻烦,而且也不利于后续项目的改动和整理 所以看了杨老师的视频https://www.bilibili.com/ ...

  6. 获取 Windows Phone 的 User-Agent 字符串

    这个是简单介绍一下如何在wp开发中获取 Windows Phone 的 User-Agent 字符串,更多wp移动开发就去那个wp教程网吧.http://wp.662p.com 使用方法 public ...

  7. wp7图片上传服务器

    做一个wp7手机上传图片到服务器的功能,具体丝路是在手机端做一个照相或者选择图片的功能,点击上传,在服务器端做一个一般处理程序,接受上传的文件,存入文件夹,下面是主要代码: 手机端代码: /// &l ...

  8. JS 100节楼梯,0-49节 分数等于节数 50以后(包括50)每节10分输入节数 得出分数

    var n = parseInt(prompt("请输入数值")); ; ; ){ ; i<n; i++) { sum = sum + i; } alert(sum); } ...

  9. mysql8下载与安装

    MySQL各版本的区别 MySQL 8.0.13安装教程(windows 64位)   编码用utf8mb4 Navicat连接mysql出现1862错误

  10. 判断list数组里的json对象有无重复,有则去重留1个

    查找有无重复的 var personLength = [{ certType: '2015-10-12', certCode:'Apple'}, { certType: '2015-10-12', c ...