JDBC(SQL语句的API)

文章详细介绍了JDBC的核心接口,包括Connection、Statement、PreparedStatement和ResultSet,阐述了JDBC连接数据库的流程,包括加载驱动、建立连接和执行SQL。同时,提到了JDBC的异常处理,并重点讨论了阿里巴巴的Druid数据库连接池,强调了其性能提升、资源节省和防止连接泄露的优点,以及使用Druid初始化连接池的基本步骤。

        JDBC(Java Database Connectivity)是java官方提供的一套API,用于连接各种数据库。它提供了一组用于执行SQL语法的java方法,以及连接到数据源和处理查询结果的一类工具和类。

        1 JDBC核心接口

                        Connection:表示数据库的连接

                        Statement:用来执行SQL语句的语句对象

                        PreparedStatenment:用来执行预编译SQL语句的语句对象

                        ResultSet:用来表示查询结果集

        不同的DBMS都会提供一套具体的实现类,并打包为jar,这个jar包被称为连接该DBMS的驱动(Driver)。

        2 JDBC使用流程

                1、pom.xml中添加MySQL数据库依赖,并刷新maven

                2、加载JDBC驱动程序

                在使用JDBC前,必须先架子啊所需的JDBC驱动程序

                class.forName("com.mysql.jdbc.Driver")

                3、建立数据库连接

                要连接到数据库,必须使用JDBC中的DriverManager类

                DriberManager类负责管理JDBC驱动程序,它使用特定的URL和属性来获取连接

String url = "jdbc:mysql://localhost:3306/tedu?
characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai&rewriteBatchedS
tatements=true";
String user = "root";
String password = "root";
Connection connection = DriverManager.getConnection(url, user, password);

                 4、执行SQL语句

                Statement对象执行SQL(静态SQL语句)

                执行SQL语句的最常用方法是使用Statement对象。Statement对象用于执行静态SQL语句

Statement statement = connection.createStatement();
String sql = "SELECT * FROM student";
ResultSet resultSet = statement.executeQuery(sql);

                 PreparedStatement对象执行动态SQL语句。

String sql = "UPDATE student SET name = ? WHERE id = ?";
PreparedStatement statement = connection.prepareStatement(sql);
statement.setString(1, "Tom");
statement.setInt(2, 1);
statement.executeUpdate();

        5、处理查询结果 

        JDBC   API提供了ResultSet对象,用于处理查询结果,可以使用ResultSet对象的getXXX方法获取查询结果中的数据

while (resultSet.next()) {
int id = resultSet.getInt("id");
String name = resultSet.getString("name");
}

 2 JDBC异常处理

        在使用JDBC时,可能会发生各种异常。JDBC API定义了SQLException类来处理这些异常。建议在应用程序中使用try-catch语句处理异常。

3 数据库连接池

简介:阿里巴巴数据库连接池(Druid)是阿里巴巴开源的一个基于JDBC数据库连接池

1、Maven依赖

<!-- 数据库连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.21</version>
</dependency>

2、优点:

提高性能
数据库连接池中可以预先创建一定数量的连接并一直保持打开状态,避免了每次请求都需要建立连
接和关闭连接的开销,从而提高了系统性能。
节省资源
数据库连接池通过避免每次请求都创建和关闭连接降低了系统中数据库连接的数量,节省了系统资
源,提高了系统的可扩展性。
避免了连接泄露
数据库连接池在使用完毕后会归还连接到连接池中,避免了长时间占用连接的情况,减少了连接泄
漏的机会。
3、使用流程
        1、首先添加pom.xml,并刷新maven
        2、初始化连接池,指定最大连接数和初始连接数DBUtil
package jdbc;
import com.alibaba.druid.pool.DruidDataSource;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class DBUtil {
// 连接池
private static DruidDataSource ds;
static {
initDataSource(); // 初始化连接池
}
private static void initDataSource(){
ds = new DruidDataSource();
ds.setUsername("root");
ds.setPassword("root");
ds.setUrl("jdbc:mysql://localhost:3306/tedu?
characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai&rewriteBatc
hedStatements=true");
ds.setMaxActive(30); // 最大连接数
ds.setInitialSize(5); // 初始连接数
}
public static Connection getConnection() throws SQLException {
return ds.getConnection();
}
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值