在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
本文将从JDBC的作用,JDBC的连接步骤和JDBC的最佳实践三个方面来详解JDBC的运行过程,感兴趣的同学可以接着往下看,相信你一定会有所收获。
一、JDBC的作用
JDBC的全称是Java DataBase Connection,也就是Java数据库连接,我们可以用它来操作关系型数据库。JDBC接口及相关类在java.sql包和javax.sql包里。我们可以用它来连接数据库,执行SQL查询,存储过程,并处理返回的结果。
JDBC接口让Java程序和JDBC驱动实现了松耦合,使得切换不同的数据库变得更加简单。
二、JDBC的连接步骤
执行一次JDBC连接,分六个步骤进行:
1. 导入包
在程序中包含数据库编程所需的JDBC类。大多数情况下,使用 import java.sql.* 就足够了。
2. 注册JDBC驱动程序
需要初始化驱动程序,这样就可以打开与数据库的通信。
3. 打开一个连接
使用DriverManager.getConnection()方法来创建一个Connection对象,它代表一个数据库的物理连接。
4. 执行一个查询
需要使用一个类型为Statement或PreparedStatement的对象(两者区别看后文),并提交一个SQL语句到数据库执行查询。
5. 从结果集中提取数据
这一步中演示如何从数据库中获取查询结果的数据。使用ResultSet.getXXX()方法来检索的数据结果。
6. 清理环境资源
在使用JDBC与数据交互操作数据库中的数据后,应该明确地关闭所有的数据库资源以减少资源的浪费。
三、JDBC的最佳实践
数据库资源是非常昂贵的,用完了应该尽快关闭它。Connection, Statement, ResultSet等JDBC对象都有close方法,调用它就好了。
在代码中必须显式关闭掉ResultSet,Statement,Connection,如果你用的是连接池的话,连接用完后会放回池里,但是没有关闭的ResultSet和Statement就会造成资源泄漏了。
在finally块中关闭资源,保证即便出了异常也能正常关闭。
大量相似的查询应当使用批处理完成。
尽量使用PreparedStatement而不是Statement,以避免SQL注入,同时还能通过预编译和缓存机制提升执行的效率。
如果你要将大量数据读入到ResultSet中,应该合理的设置fetchSize以便提升性能。
你用的数据库可能没有支持所有的隔离级别,用之前先仔细确认下。
数据库隔离级别越高性能越差,确保你的数据库连接设置的隔离级别是最优的。
如果你需要长时间对ResultSet进行操作的话,尽量使用离线的RowSet。
以上就是JDBC的运行过程的全部内容,都是干货哟,还不明白的同学可以上博学谷官网进行咨询。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Activity生命周期的知识点详解
在掌握Android应用开发的学习过程中,Activity生命周期相关知识点是必须掌握的基础内容。本文将会为大家详解Activity生命周期的有关知识,带大家了解什么是Activity生命周期,生命周期的流程以及四个状态,最终达到帮助大家完整掌握Activity用法的目的。下面就让我们一起来学习一下Activity的生命周期吧!
5069
2020-02-04 15:39:14
2020年2月IT编程语言排行榜名单有哪些变化?
2020年2月份TIOBE公布了IT行业编程语言排行,排名Top4的IT编程语言的排名没有太大变化,Java依旧稳居榜首,其次分别是C、Python、C++。IT编程语言排行前五名是 Java、C、Python、C++ 和 Visual Basic.NET。Python稳坐前三,Visual Basic.NET迅猛增长。
6201
2020-02-11 15:21:32
自学Android编程入门难吗
自学android编程入门难吗?难在于你是否用心,是否坚持,如果你真的克服了困难,那android编程入门对你来说是新的开始。而且Android应用开发已得到众多企业的追捧,发展前景无比诱人。所以小编这里给大家提供了android编程入门自学方案,希望能够对你有帮助。
5321
2020-04-01 17:55:03
5G时代大公司需要什么IT技能?
5G时代大公司需要什么IT技能?如今5G时代已经来临,互联网的迭代升级促进了IT行业的进一步发展,与此同时IT产业为了适应新的技术的变化,也需要不断调整最新的IT技能。
4949
2020-06-03 14:37:06
零基础转行IT学什么好?
IT岗位普遍高于传统行业的薪资水平,吸引了不少零基础的转行者。然而许多转业者一开始都难免面临这样的问题:零基础转行IT学什么好?IT技术岗位一般大致分为开发、测试和运维。随着软件产业的发展,这三种岗位都变得同样重要,技能要求也越来越广泛。比如测试岗位如今也要求具备一定的编程能力。因此,不管你选择什么岗位,只要技术过硬,都有着极大的发展前景。下面我们就来逐一分析适合零基础学习的IT技术。
5587
2020-07-24 16:33:40