JDBC原理及使用步骤

1、原理

JDBC API 允许用户访问任何形式的表格数据,尤其是存储在关系数据库中的数据。

在这里插入图片描述

JDBC中主要的设计模式

  • 桥接模式 (主要)
  • 工厂模式
  • 单例模式
  • 装饰者模式

2、使用步骤

前提:导包

<dependencies>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.25</version>
    </dependency>
</dependencies>

1)配置信息

  • 驱动

    如果选用后面第二种方式加载驱动,直接new,此处驱动不用显式指明,可以省略

// mysql-connector-java 6及以上用:com.mysql.cj.jdbc.Driver
String driver = "com.mysql.cj.jdbc.Driver";

// mysql-connector-java 6 以下用 com.mysql.jdbc.Driver
String driver = "com.mysql.jdbc.Driver";
  • url
// 新版驱动需要加安全检查:useSSL=true
// 连接符 & 及转义符 &amp; ,因配置环境不同,有时可以直接用 &,有时需要转义 &amp;

String url = "jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;useUnicode=true&amp;characterEncoding=utf8";

String url = "jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8";

String url = "jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=GMT";

String url = "jdbc:mysql://localhost:3306/mybatis?useUnicode=true&amp;characterEncoding=utf-8";
  • 用户名
String username = "root";
  • 密码
String ps = "123456";

2)加载驱动

  • 方式一:反射
Class.forName(driver);
  • 方式二:直接创建new
// com.mysql.cj.jdbc.Driver()
DriverManager.registerDriver(new Driver());

3)连接数据库

连接成功后的 Connection 对象就相当于数据库

Connection connection = DriverManager.getConnection(url, username, ps);

4)获取SQL对象

SQL对象(Statement、PreparedStatement)

PreparedStatement:预编译SQL对象,SQL语句中指明占位符

Statement statement = connection.createStatement();

5)编写SQL

String sql = "select * from people";

6)执行SQL

ResultSet resultSet = statement.executeQuery(sql);

7)输出结果

// ---输出---
while (resultSet.next()) {
    System.out.print(" id:" + resultSet.getObject("id"));
    System.out.print(" name:" + resultSet.getObject("name"));
    System.out.println();
}

8)关闭/释放

关闭连接/释放资源

先关里层、后关外层

resultSet.close();
statement.close();
connection.close();

总结

只有第5步编写SQL语句需要变化,其余步骤基本上固定,不需要变化;可以把这个执行过程封装起来使用

3、事务

1)开启

// 默认自动提交
// 设为false,相当于关闭自动提交,需要手动提交,等价于开启事务
connection.setAutoCommit(false);         

2)提交

connection.commit();

3)回滚

connection.rollback();
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

土味儿~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值