如何正确地创建和销毁软件应用系统中JDBC数据库连接对象实例
sinye56 2024-10-04 23:53 8 浏览 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){
}
}
相关推荐
- Linux中10大常用命令之sort使用案例
-
请关注本头条号,每天坚持更新原创干货技术文章。如需学习视频,请在微信搜索公众号“智传网优”直接开始自助视频学习1.前言Linux中的sort命令用于对文本文件的内容进行排序。本教程向您展示了sort...
- java开发常用的Linux命令,高频的没你想象的多
-
Linux的命令非常多,多到有些使用的场景你工作两三年也没有遇到过,工作三四年才能遇到(Linux内核开发,Shell脚本开发,嵌入式开发、、、),但这个不是今天分享的重点,今天分享的重点是Java开...
- linux常用命令(收藏版)
-
linux小白注意啦,给大家分享一点干货,请笑纳!1.关机命令shutdown-hnow关闭系统(1)init0关闭系统(2),0为系统的进程号telinit0关闭系统(3)shutdo...
- 延续Win10三年需付超3000元!微软彻底封堵:删除绕过Win11系统要求教程、将第三方工具标记为恶意软件
-
一切都是为了用户能够正规地升级到Windows11。整理|屠敏出品|CSDN(ID:CSDNnews)距离Windows10退役仅剩8个月,微软最近这段时间,终是忍不住接连出手了...
- 敲完就让你提桶跑路的Linux命令
-
不谨慎可能就会让你提桶的Linux命令!!!删除文件rm-rf该命令是删除文件或文件夹等最快的方式之一。删除后的内容很难恢复,如果删除系统文件可能会导致系统崩坏。˃rm-rf/#强制删除根...
- 超级蠕虫,累计感染40万台服务器,让Linux内核服务器感染两年
-
最近著名安全公司ESET发布安全报告,报告分析了其对一个超级蠕虫Ebury的15年追踪分析。在15年中该病毒持续感染了40万台服务器,曾经在2011年(2009年)攻克了Linux内核维护站点kern...
- linux redhat破解密码
-
适用于RedhatCentosFedora1.开机选择第一个启动项,按e进入编辑模式2.在启动项编辑模式找到linux16开头的文件,按ctrl+e快速定位到该行的行末,输入空格rd.break...
- 慎用!Linux最危险的10个命令!
-
Linux是一个强大而灵活的操作系统,它提供了许多功能丰富的命令和工具,让用户可以方便地管理和控制系统。但是,有些命令如果不小心或不知情地使用,可能会造成严重的后果,甚至导致系统崩溃或数据丢失。因此,...
- Linux文件和目录删除
-
今天只讲一个命令,这个命令已经让万千运维人既爱又恨。rm删除文件或者目录基本用法:-i显示删除提示信息-f强制删除文件-r进行目录的递归删除在公司里为了保证数据安全,一般会创建一个alias...
- 给你的Linux系统穿上“防弹衣”:安全加固全攻略
-
为什么Linux系统需要安全加固在当今数字化时代,Linux系统以其开源、稳定、高效等特性,在服务器领域占据着举足轻重的地位。无论是大型互联网公司的核心业务,还是中小企业的日常运营,都离不开L...
- 一天一个Linux命令:文件操作「删」rm
-
命令:rm-rf文件名(慎用,慎用,慎用)rm(选项)(参数)命令功能:rm-rf是一条UNIX系统下的文件删除命令,作用是无提示地强制递归删除一个目录中的一个或多个文件或目录,如果没有使用...
- Linux下通过 rm -f 删除大量文件时报错:Argument list too long
-
问题现象云服务器ECSLinux下通过rm-f删除大量的小文件时出现类似如下错误信息:-bash:?/bin/rm:?Argument?list?too?long如下图所示:问题原因如?待删...
- 这10个Linux命令太危险,千万慎用!数据毁灭的瞬间只需一个回车
-
你好,这里是网络技术联盟站,我是瑞哥。Linux系统,以其开源自由的特性,吸引了无数开发者和科技爱好者。其强大的命令行工具赋予了用户前所未有的控制能力。然而,正如俗话所说,“能力越大,责任越大”。某些...
- Linux的10大危险命令,用过的运维都很刑
-
rm-rf命令该命令可能导致不可恢复的系统崩坏。˃rm-rf/#强制删除根目录下所有东西。˃rm-rf*#强制删除当前目录的所有文件。˃rm-rf.#强制删除当前...
- Linux环境变量设置与查看全攻略
-
Linux环境变量设置与查看全攻略在Linux系统中,环境变量是用于定义系统和用户级设置的一种方法,它可以影响程序的行为和系统的运行方式。了解如何设置和查看环境变量对于Linux用户来说是非常重要的技...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle忘记用户名密码 (59)
- oracle11gr2安装教程 (55)
- mybatis调用oracle存储过程 (67)
- oracle spool的用法 (57)
- oracle asm 磁盘管理 (67)
- 前端 设计模式 (64)
- 前端面试vue (56)
- linux格式化 (55)
- linux图形界面 (62)
- linux文件压缩 (75)
- Linux设置权限 (53)
- linux服务器配置 (62)
- mysql安装linux (71)
- linux启动命令 (59)
- 查看linux磁盘 (72)
- linux用户组 (74)
- linux多线程 (70)
- linux设备驱动 (53)
- linux自启动 (59)
- linux网络命令 (55)
- linux传文件 (60)
- linux打包文件 (58)
- linux查看数据库 (61)
- linux获取ip (64)
- linux进程通信 (63)