百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

如何正确地创建和销毁软件应用系统中JDBC数据库连接对象实例

mhr18 2024-09-21 19:04 21 浏览 0 评论

软件项目实训及课程设计指导——如何正确地创建和销毁软件应用系统中JDBC数据库连接对象实例

1、Java语言中提供有访问数据库系统的JDBC编程接口

Java 数据库连接技术(JDBC,Java DataBase Connectivity)其实是将Java语言与标准的SQL(Structured Query Language,结构化查询语言)语句相互结合且独立于特定的物理数据库系统的一种应用程序的编程接口。

之所以要提出JDBC 编程接口,其主要的目的首先是推广Java语言的应用范围以胜任企业级软件应用系统的开发,因为企业级软件基本上都涉及到物理数据库系统,如果Java应用不能访问数据库系统,则意味着Java平台不适宜与企业级应用系统。

其次,是希望改进当时微软公司所提出的ODBC(Open Database Connectivity,开放数据库连接)编程接口所存在的平台问题,因为ODBC编程接口只适用于Windows操作系统。也就意味着如果在Java应用中应用ODBC编程接口,则只能连接Windows操作系统平台下的数据库系统,并且该Java 应用也只能应用于Windows操作系统平台。Java 应用所具有的跨平台特性将伤失和Java 应用不能操作非Windows操作系统平台的数据库系统(如Linux系统中的数据库系统、Unix系统中的数据库系统等)。这是不可想象的可怕后果!

最后,希望能够为Java平台中的各种应用系统提供一种通用的数据库访问的接口,减轻软件应用系统开发人员编程开发数据库应用相关程序的复杂性。

2、JDBC是一种可用于执行SQL语句的Java API规范

(1)JDBC提供了一种标准的应用程序设计接口

JDBC 编程接口为软件应用系统中涉及数据库应用相关的开发人员、数据库前台工具开发人员都提供了一种标准的应用程序设计接口,使软件应用系统的开发人员可以用纯Java语言编写完整的数据库应用程序。

如下示图所示为MyEclipse开发工具中所提供的MyEclipse Database Explore数据库系统透视图功能的菜单项目,而该功能就是应用JDBC接口操作访问用户所指定的物理数据库系统。

(2)JDBC为基于数据库系统的各种Java应用提供如下三个方面的功能

1)创建与物理数据库系统的连接,从而可以操作和访问目标数据库系统中的数据;

2)发送标准的SQL语句到指定的关系型数据库系统中,该SQL语句封装对目标数据的操作要求;

3)处理数据并查询处理后的返回结果,该结果以结果集的形式返回给上层的应用,应用系统解析返回的结果集并最终获得所需要的目标数据。

如下示图为Oracle公司官方发布的JDBC技术参考文档中对JDBC的技术特性介绍的部分文字的局部截图,读者可以更加权威地了解到JDBC编程接口的主要功能。

3、JDBC数据库连接Connection对象的主要作用

软件应用系统的开发人员要想在Java程序中访问和操作物理数据库系统中的数据,首先需要创建出 java.sql.Connection数据库连接对象实例。然后在Connection对象实例的基础上再构造出相应的语句(如Statement类型或者PreparedStatement类型)类对象实例。

所有的数据库访问操作都是在Connection对象实例的基础上完成的,它代表对数据库表中数据访问的一次会话。因此,软件应用系统的开发人员有必要正确地创建出Connection类的对象实例。

如下示图为JDK API系统库的技术参考文档中对Connection接口的功能介绍文字的局部截图。

4、JDBC连接数据库系统的数据源相关的URL字符串规范

(1)标识物理数据库系统数据源的URL字符串规范

标识物理数据库系统数据源的URL字符串的格式如下所示: jdbc:<subprotocal>:[database locator]

其中的"jdbc"主要指出要使用JDBC编程接口,而"subprotocal"主要是定义驱动程序类型,"database locator"则是提供网络数据库的位置和端口号(包括主机名、端口和数据库系统名等)。示例如下:jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs

(2)JDBC URL 字符串规范提供了一种标识物理数据库系统的标准

应用JDBC URL 字符串规范,可以使得相应的物理数据库系统的Java JDBC的驱动程序能识别出所要连接的目标物理数据库系统的类型、网络位置以及数据库名称等信息,从而实现与目标数据库系统建立连接。

但由于JDBC编程接口只对JDBC URL字符串提出了"形式"方面的规范要求,并没有给出具体和统一的URL字符串模板。因此,在Java应用系统程序中连接不同的数据库系统或者同一种数据库系统的不同版本、不同的连接方式等,所对应的JDBC URL字符串可能都存在差别。

因此,读者在数据库系统应用相关的开发中容易给出错误的JDBC URL字符串,导致无法正确地连接到目标数据库系统。因为JDBC的Java驱动程序的编程实现人员将决定采用什么内容的JDBC URL来标识所开发的特定驱动程序;不同厂商的物理数据库系统,在Java应用中的主要差别在于JDBC的驱动程序类型及标识物理数据库系统的JDBC URL字符串。

1)连接Oracle数据库系统时的JDBC URL字符串为:jdbc:oracle:thin:@10.172.0.107:1521:DBName;

2)连接MS SQLServer数据库系统时,数据库在IP地址为10.172.0.105的远程主机时的JDBC URL字符串为:jdbc:microsoft:sqlserver://10.172.0.105:1433;DatabaseName=pubs;如果MS SQLServer数据库系统在本机中,则其中的IP地址10.172.0.105改变为127.0.0.1:1本机IP地址。

3)连接MySQL数据库系统时的JDBC URL字符串为:jdbc:mysql://localhost:3306/webbank,其中的"localhost"代表物理数据库系统就在本机中,如果物理数据库系统位于远程主机中,则需要将其中的"localhost"改变为远程主机的IP地址。

5、正确地构造本数据库连接的JDBC数据源URL地址

根据上面对JDBC URL字符串的介绍,读者可以了解到JDBC数据源URL地址提供了一种标识目标数据库文件的方法,可以使相应的JDBC驱动程序能识别出该数据库系统并与之建立对应的连接。

当然,JDBC的Java驱动程序的开发实现人员将决定用什么内容或者特定标识字符所构成的JDBC数据源URL地址来标识特定的数据库系统;不同厂商的物理数据库系统在Java应用中的主要差别在于JDBC的驱动程序类名称及JDBC数据源URL地址的格式。

软件应用系统的开发人员应该首先了解所要连接的数据库类型和所要采用的JDBC的驱动程序类型,然后再根据该JDBC的驱动程序类型构造出对应的JDBC数据源URL地址字符串,一般在JDBC的驱动程序提供者所提供的帮助文档中有详细的文档说明。

6、获得某个数据库系统的JDBC驱动程序类的类名称字符串

同一种物理数据库系统可能会存在多种不同形式的JDBC驱动程序类,因为这些JDBC驱动程序类可能是由不同的厂商或者开源机构或者人员所提供。因此,软件应用系统的开发人员在构造数据库连接Connection对象实例之前还必须正确地了解所应用的JDBC驱动程序类的类名称字符串。

(1)连接Oracle数据库时的JDBC驱动程序类的类名称字符串为:oracle.jdbc.driver.OracleDriver;

(2)连接MS SQLServer数据库时的JDBC驱动程序类的类名称字符串为:com.microsoft.jdbc.sqlserver.SQLServerDriver;

(3)连接MySQL数据库时的JDBC驱动程序类的类名称字符串为:com.mysql.jdbc.Driver。

7、如何正确地创建出数据库连接Connection类型的对象实例

在构造数据库连接Connection对象实例之前,首先要利用Class类中的static形式的forName静态方法加载JDBC驱动程序类,然后再利用DriverManager接口中所提供的getConnection方法获得指定的Connection对象实例。

如下为正确地创建出数据库连接Connection对象实例的程序代码片段示例:

try {
				Class.forName("JDBC驱动程序类名称");
}
catch (java.lang.ClassNotFoundException e){
}
try {
				oneConnectionObject= DriverManager.getConnection("JDBC数据源URL地址");
}
catch (java.sql.SQLException e){
}
catch (NullPointerException e){
}

8、分离创建数据库连接对象中所需要的各种连接信息

由于在构造数据库连接Connection对象实例时,一般需要提供JDBC数据源URL地址、JDBC驱动程序类名称以及在数据库系统中所建立的账户和密码(该账户有访问数据库系统的权限)等方面的信息。

而这些信息是有可能经常发生变化的(比如访问数据库系统的账户所对应的密码),如果直接将这些信息写在程序代码中将导致程序代码缺乏灵活性——当数据库连接有关的信息发生变化时,则需要改动创建数据库连接Connection对象实例的有关程序代码,导致程序代码缺少灵活性。

如下示图中的程序代码示例是不良好的JDBC数据库应用的程序代码,因为将物理数据库系统的类型、网络位置、数据库名称、连接账户和密码等信息都直接硬编码的方式写入到程序代码中。

为了能够提高程序代码的灵活性,应该要分离创建数据库连接对象中所需要的各种连接信息,并将这些连接信息保存到一个外部配置文件中——比如,可以采用Java属性配置文件(*.properties)或者XML格式的配置文件(*.xml),读者可以参见如下示图中的Java属性配置文件的配置示例。

在示例项目银行账户信息管理系统中是利用XML格式的系统配置文件classNameConfig.xml存放创建数据库连接Connection对象实例中所需要的各种连接信息,如下代码示例为XML配置文件classNameConfig.xml中的部分代码示例。

<?xml version="1.0" encoding="UTF-8"?>
 <classNames>
      <className>
          <classNameID>JDBC_DBDriver_ClassName</classNameID>
          <classNamePath>com.mysql.jdbc.Driver</classNamePath>
      </className>
      <className>
          <classNameID>JDBC_DSN_URL</classNameID>
          <classNamePath>jdbc:mysql://localhost:3306/webbank</classNamePath>
      </className>
      <className>
          <classNameID>JDBC_dbUserName</classNameID>
          <classNamePath>root</classNamePath>
      </className>
      <className>
          <classNameID>JDBC_dbUserPassWord</classNameID>
          <classNamePath>root</classNamePath>
      </className>
</classNames>

然后在程序中应用XML解析技术动态获得保存在XML配置文件中的数据库连接信息,最后将这些连接信息传递给DriverManager.getConnection()方法,请见下图所示的程序代码片段截图。

9、如何正确地关闭数据库连接Connection对象实例

当在程序代码中构造出数据库连接Connection的对象实例后,Java虚拟机JVM系统同样也需要为它分配有关的各种系统资源。因此,当不再需要该数据库连接Connection的对象实例后,也应该要及时地关闭Connection的对象实例以释放它所占用的系统资源。

下面为关闭数据库连接Connection对象实例的代码片段示例,并且要将这些代码放在finally 关键字所标识的语句块中:

finally{
    try{
          /** oneConnectionObject代表Connection接口的对象实例 */
          oneConnectionObject.close();
          oneConnectionObject = null;
    }
    catch (SQLException e){
    }
}

相关推荐

mysql一 基本操作(mysql基础操作命令)

先讲数据库--mysql、redis、MongoDB爬虫今天的内容:mysql一基本操作注意事项:1.安装:自己安装,有问题可以问老师、可以自己找办法解决2.上课:先讲知识点再回答问题3....

香港DM德馬景泰藍文科集團20250702期《生命的收獲》LIN JING DE

香港DM德馬景泰藍文科集團20250702期《生命的收獲》DMSIXSEVEN/LINJINGDE/1973主編供圖:香港DM德馬數字甲骨文集團Hongkong-basedDMDelm...

01.Java发展历史(java发展简史)

1.Java发展历史Java由SunMicrosystems公司(现为Oracle公司)的JamesGosling及其团队在1991年开发,最初命名为"Oak",后改名为"...

月薪最高12000!看看这些宝山岗位有没有你心仪的~

招聘目录信息1猎上网络科技(上海)有限公司职位分析师职位分析师助理2上海祥腾金属材料有限公司商务车驾驶员3上海赋拓物联网技术有限公司软件测试工程师4上海集优标五高强度紧固件有限公司...

69岁的Java之父终于退休了,他竟然也经历过职场PUA

有些程序员不到35岁就要担心被优化,但有的程序员干到了69岁的高龄,才准备退休。就前几天,Java之父詹姆斯·高斯林,自个儿在领英上宣布以后要美美享受退休生活了。这一下子,就炸出了不少...

ocm认证年薪多少?(ocm认证好考吗)

从业数据库方面的工程师待遇都很好,年薪30万都是比较平常的事。OCM认证的价值可以归纳成以下几点:1、可以全面掌握Oracle知识,专业知识完善;2、证书对于公司招投标有巨大作用,甚至可以不上班就拿钱...

自学java开发攻略,想做程序员的必备攻略?

背景现阶段,随着互联网的快速发展,程序员这个行业越来月吃香,不仅仅是因为科技先进,说出去很牛逼,让别人产生崇拜,主要原因是程序员行业薪资待遇好,相比国内其他行业,程序员的薪资待遇是羡慕了很多人呢!于是...

SpringBoot WebFlux整合R2DBC实现数据库反应式编程

环境:Springboot2.4.12R2DBC简介SpringdataR2DBC是更大的Springdata系列的一部分,它使得实现基于R2DBC的存储库变得容易。R2DBC代表反应式关系数...

AI编码工具未能代替码农:大模型的局限性揭秘

随着ChatGPT和GithubCopilot等AI编码工具的兴起,StackOverflow近日因流量减少宣布裁员近三分之一。这引发了一个争议的问题:ChatGPT这类AI编码工具,真的要颠覆整...

大模型无法替代码农!GPT-4解决GitHub编程问题成功率为0

编辑:编辑部【新智元导读】ChatGPT之类的AI编码工具来势汹汹,StackOverflow又裁员了!不过,普林斯顿和芝大竟发现,面对真实世界GitHub问题,GPT-4的解决率竟是0%。Stac...

机器人动作领域突破!UniVLA模型实现跨模态AI机器人动作统一

还记得《星际穿越》中那台能在无重力、尘暴甚至巨浪中切换形态、随时理解库珀指令的TARS多功能机器人吗?在银幕里,我们羡慕TARS能听懂人话、看懂环境、马上给出最合适的动作;而在现实世界的实验室里,“让...

FEA-Bench:首个仓库级新功能实现基准,让大模型更懂软件开发

当前,大语言模型在代码生成领域已展现出惊人的能力,但能否胜任真实软件开发中的“新增功能实现”任务,仍是一个关键未解的问题。对此,微软亚洲研究院与北京大学联合发布了首个专注于仓库级新功能实现的基准测试...

基于Java的软件版本信息管理系统-2025计算机毕业设计

基于Java的软件版本信息管理系统-2025计算机毕业设计前言随着移动互联网的快速发展,APP已成为人们日常生活中不可或缺的一部分。为了高效地管理这些APP的信息,如版本更新、用户反馈、下载量统计等,...

马斯克在干嘛?抱着它现身推特 简介改为“推特老板”

  马斯克收购推特的交易真是“没完没了”。据彭博社报道,当地时间26日,美国亿万富翁埃隆·马斯克抱着水槽走进了推特公司的旧金山总部,他还将自己在推特账号的公开自我介绍改为“推特老板”(ChiefTw...

福布斯公布7月全球十大富豪:马斯克成6月最大“输家”,身家缩水160亿美元

7月日,福布斯今日公布了2025年7月全球十大富豪榜,其中第二名迎来新面孔。软件巨头甲骨文(Oracle)联合创始人兼董事长拉里埃里森(LarryEllison)凭借公司股价飙升成功上位。由...

取消回复欢迎 发表评论: