栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JDBC原理及使用步骤

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JDBC原理及使用步骤

1、原理

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

JDBC中主要的设计模式

  • 桥接模式 (主要)
  • 工厂模式
  • 单例模式
  • 装饰者模式
2、使用步骤

前提:导包


    
        mysql
        mysql-connector-java
        8.0.25
    

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
// 连接符 & 及转义符 & ,因配置环境不同,有时可以直接用 &,有时需要转义 &

String url = "jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&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&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();
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/666715.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号