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. Intellij IDEA社区版打包Maven项目成war包,并部署到tomcat上

    转自:https://blog.csdn.net/yums467/article/details/51660683 需求分析 我们利用 Intellij idea社区版IDE开发了一个maven的sp ...

  2. golang 初体验

    1.下载golang https://code.google.com/p/go/downloads/list 在windows下安装,下载windows32版本 2.安装 安装完毕,默认在C:\Go ...

  3. C# Log4Net简单使用方法

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

  4. 用户注册登录验证 多版本集合 + hashlib加密

    #!/usr/bin/env python# -*- coding: utf-8 -*-# @Time : 2018/5/6 0006 12:22# @Author : Anthony.Waa# @S ...

  5. [转]Java设计模式学习心得

    http://tech.it168.com/focus/200902/java-design/index.html http://tech.it168.com/j/2007-05-17/2007051 ...

  6. 1) 十分钟学会android--建立第一个APP,创建android项目

    一个Android项目包含了所有构成Android应用的源代码文件. 本小节介绍如何使用Android Studio或者是SDK Tools中的命令行来创建一个新的项目. Note:在此之前,我们应该 ...

  7. VS2015 & ReSharper CTRL

    如下为个人比较常用的快捷键,部分快捷键有进行修改. 一.VS偏好设置: 1.转到定义:F12 2.查找所有引用:Shift + F12 3.跳转到指定的某一行:Ctrl + G (or 单击状态栏中的 ...

  8. MongoDB_pymongo

    python使用pymongo访问MongoDB的基本操作 安装pymongo: pip install pymongo from pymongo import MongoClient import ...

  9. UWP 利用DataGrid控件创建表格

    通过 Nuget 搜索 Microsoft.Toolkit.Uwp.UI.Controls.DataGrid 安装库,在XAML文件中添加引用库 xmlns:controls="using: ...

  10. 企业级任务调度框架Quartz(9) Quartz之作业触发器Trigger

    前序:      我们已经大概对Quartz的基本有了一个大概的认识:现在我们将要逐渐对Quartz的各个重要组件进行学习:前面已经对job进行了详细讲解,现在我们来认识下它的一个重要兄弟,没有它,作 ...