【Java|数据库】使用JDBC连接数据库 (超详细)

本文详细介绍了如何使用Java JDBC连接MySQL数据库,包括JDBC的基础概念、架构和规范,连接数据库的步骤,如加载驱动、建立连接、执行SQL以及释放连接。此外,还提供了在程序和配置文件中配置连接信息的实例,以及使用Statement和PreparedStatement接口进行增删改查操作的指南。
摘要由CSDN通过智能技术生成

【Java|数据库】使用JDBC连接数据库 (超详细)


1. 基础

(点击跳过本节)

概念

JDBC的全称是Java Database Connectivity,意为Java和数据库的连接。

JDBC是SUN公司提供的一套操作数据库的接口规范,定义了用来访问数据库的标准Java类库,使用这个类库可以更加方便地访问数据库资源。

程序员在使用数据库的时候,需要安装数据库驱动,不同的数据库的驱动也是不同的。所以为了程序员开发方便,SUN公司提供了一套接口,让数据库厂商实现这些接口,程序员只需要使用这个接口就可以操作不同的数据库,不需要关注底层数据库驱动的安装,从而大大简化和加快了开发过程。


架构

JDBC接口包括两个层次:

JDBC API:即面向应用的API,是一个抽象的接口,供应用程序开发人员使用,提供了程序到JDBC管理器的连接。

JDBC Driver API:即面向数据库驱动的API,需要开发商去实现这个接口,提供了JDBC管理器到数据库驱动程序的连接。
在这里插入图片描述


规范

主要有四个核心对象:

DriverManager(java.sql.DriverManager): 用于注册驱动,创建连接对象。
Connection接口(java.sql.Connection):     表示与数据库创建的连接。
Statement接口(java.sql.Statement):       执行数据库SQL语句,并返回相应结果的对象。
ResultSet接口(java.sql.ResultSet):       结果集或一张虚拟表,用于存储表数据的对象。

其中,Statement接口还有两个子接口:

PreparedStatement接口(java.sql.PreparedStatement):
			预编译对象,是Statement接口的子接口,用于解决sql的注入问题。
CallableStatement接口(java.sql.CallableStatement):
			支持带参数的SQL操作,支持调用存储过程,是PreparedStatement接口的子接口。

2. 连接数据库

(点击跳过本节)
下面的说明以连接MySQL数据库为例。


准备工作

拥有一个可以正常访问的MySQL数据库,已经可以登录使用的用户名和密码。

建立一个准备连接数据库的项目。


导入jar包

导入Java连接MySQL所用到的jar包,这个jar包通常是由数据库的厂商提供的,这里下载的是 mysql-connector-java-5.1.32.jar 这个包。

那Eclipse为例(不想看可以跳过),在项目上右键,然后点击Properties:

在这里插入图片描述

然后在弹出的页面左侧找到 Java Build Path 目录并进入,选择 Libraries 标签页,找到标签页右侧的 Add External JARs... 按钮:

在这里插入图片描述
找到下载的jar包,点击打开:
在这里插入图片描述
可以看到jar包被成功导入到项目中:

在这里插入图片描述
点击OK完成导入。


加载驱动

加载数据库驱动的方法是调用Class类的静态方法forName。语法格式如下:

public static Class<?> forName(String className)

其中,传入的参数className是每个数据库厂商各自提供的一个驱动程序名称。

不同的数据库,驱动程序名称如下:

1 MySQL驱动:      com.mysql.jdbc.Drive
2 Oracle驱动:     oracle.jdbc.driver.OracleDriver
3 SQLServer驱动:  com.microsoft.sqlserver.jdbc.SQLServerDriver
4 PostgreSQL驱动: org.postgresql.Driver
5 DB2驱动:        com.ibm.db2.jdbc.net.DB2Driver
6 Sybase驱动:     com.sybase.jdbc.SybDriver

建立连接

使用DriverManager类的静态方法getConnection建立到指定数据库的连接。语法格式如下:

public static Connection getConnection(String url, String user, String password)

url是SUN公司与数据库厂商之间的一种协议,user是连接数据库的用户名,password是用户名对应的密码。

不同的数据库,url协议的格式如下:

1 MySQL格式:      jdbc:mysql://地址或主机名:端口号/数据库名
2 Oracle格式:     jdbc:oracle:thin:@地址或主机名:端口号:数据库名
3 SQLServer格式:  jdbc:sqlserver://地址或主机名:端口号;databaseName=数据库名
4 PostgreSQL格式: jdbc:postgresql://地址或主机名:端口号/数据库名
5 DB2格式:        jdbc:db2:地址或主机名:端口号/数据库名
6 Sybase格式:     jdbc:sybase:Tds:地址或主机名:端口号/数据库名

如果是在本机并且用的是默认的端口号,可以将地址和端口号省略:

jdbc:mysql:///数据库名

建议url中的文件编码、数据库连接编码、数据库编码保持一致,向数据库中添加数据时,连接参数最好包含Unicode字符支持,这样添加的字符就能被数据库识别并且正常显示了:

jdbc:mysql://地址或主机名:端口号/数据库名?useUnicode=true&characterEncoding=UTF-8

至此,就成功获取到了连接MySQL数据库的Connection对象。


执行语句

获取到连接之后,使用Connection接口的createStatement方法获取Statement对象。语法格式如下:

Statement createStatement()

获取到了Statement对象之后,使用executeQuery方法执行查询语句得到ResultSet类型的结果集,使用executeUpdate方法执行增加、删除、修改语句得到int类型的记录数。


释放连接

数据库连接Connection是非常稀有的资源,用完后必须马上释放,如果Connection不能及时正确的关闭将导致系统宕机。Connection的使用原则是尽量晚创建,尽量早的释放。

释放的方法是通过调用Connection的close方法,语法格式如下:

void close()

一次完整的操作数据库的流程包括加载驱动、建立连接、执行语句、释放连接。其中,加载驱动只执行一次即可,建立的连接用完之后必须马上释放。


3. 连接数据库实例

(点击跳过本节)

在程序里配置连接信息

完整代码如下:

public static void main(String[] args) {
   
    try 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值