IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> JDBC 获取数据库连接的5种方式 -> 正文阅读

[大数据]JDBC 获取数据库连接的5种方式

?写在前面?

📢今天我们进行 JDBC 获取数据库连接的5种方式 的学习,感谢你的阅读,内容若有不当之处,希望大家多多指正,一起进步💯!!!
??如果觉得博主文章还不错,可以👍三连支持?一下哦😀

??JDBC 获取数据库连接的5种方式

🍀JDBC程序编写步骤

1.注册驱动 - - -加载Driver
2.获取连接 - - -得到Connection
3.执行sql语句 - - -发送sql给MySQL执行
4.释放资源 - - -关闭相关连接

🍃准备工作

导入mysql-connection-java-8.0.28.jar第三方jar包(如果mysql是5.7版本导入相对性的版本)

在这里插入图片描述

在项目目录下创建目录libs,并将上述jar包复制到该目录下

在这里插入图片描述

右键jar包,点击Add As Library…

在这里插入图片描述

点击OK

在这里插入图片描述

🌿方式一

@Test
public void test01() throws SQLException {
    //1.加载数据库驱动
    Driver driver = new Driver();

    //2.连接数据库
    String url = "jdbc:mysql://localhost:3306/java2022";

    Properties properties = new Properties();
    properties.setProperty("user", "root");
    properties.setProperty("password", "111111");

    Connection connect = driver.connect(url, properties);


    //3.执行sql
    String sql = "delete from student where SID = 7";

    Statement statement = connect.createStatement();

    int i = statement.executeUpdate(sql);
    System.out.println(i > 0 ? "操作成功" : "操作失败");

    //关闭资源
    connect.close();
    statement.close();
}

🍁 解读

1.注册驱动 - - -加载Driver
创建driver对象在这里插入图片描述
2.获取连接 - - -得到Connection在这里插入图片描述
3.执行sql语句 - - -发送sql给MySQL执行
statement 用于执行静态 SQL 语句并返回其生成的结果的对象
在这里插入图片描述
4.释放资源 - - -关闭相关连接
在这里插入图片描述

🌳方式二

方式一 是直接通过new的方式创建com.mysql.cj.jdbc.Driver()对象(如果是mysql5.0版本使用的是com.mysql.jdbc.Driver(),这里是mysql8.0版本),属于是静态加载,灵活性差,依赖性强。
方式二 使用反射加载Driver类动态加载,更加的灵活,减少依赖性
在这里插入图片描述

@Test
public void test02() throws ClassNotFoundException, IllegalAccessException, InstantiationException, SQLException {
    //加载数据库驱动  通过反射的方式加载Driver类
    Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
    Driver driver = (Driver) aClass.newInstance();

    //获取连接
    String url = "jdbc:mysql://localhost:3306/java2022";
    Properties properties = new Properties();
    properties.setProperty("user", "root");
    properties.setProperty("password", "111111");
    Connection connect = driver.connect(url, properties);

    //执行sql语句
    Statement statement = connect.createStatement();
    String sql = "insert into student values(7,'王昭君',19,'女')";
    int i = statement.executeUpdate(sql);
    System.out.println(i > 0 ? "操作成功" : "操作失败");

    //关闭资源
    connect.close();
    statement.close();
}

🌴方式三

方式三 使用DriverManager替换Driver
在这里插入图片描述

@Test
public void test03() throws ClassNotFoundException, IllegalAccessException, InstantiationException, SQLException {
    //加载数据库驱动
    Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
    Driver driver = (Driver) aClass.newInstance();

    String url = "jdbc:mysql://localhost:3306/java2022";
    String user = "root";
    String password = "111111";


    //获取连接
    DriverManager.registerDriver(driver); //注册Driver驱动
    Connection connection = DriverManager.getConnection(url, user, password);
    Statement statement = connection.createStatement();

    //执行sql语句
    String sql = "insert into student values(8,'吕布',20,'男')";
    int i = statement.executeUpdate(sql);
    System.out.println(i > 0 ? "操作成功" : "操作失败");

    //关闭资源
    connection.close();
    statement.close();

}

🌵方式四

方式四 使用 Class.forName自动完成注册驱动, 简化代码,推荐使用。
在代码中没有指明注册驱动也可以获取数据数据连接,这是因为在加载Driver类时,为我们自动完成了注册驱动。
在这里插入图片描述

@Test
public void test04() throws ClassNotFoundException, IllegalAccessException, InstantiationException, SQLException {
    //加载数据库驱动
    Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
    Driver driver = (Driver)aClass.newInstance();

    //获取连接
    String url = "jdbc:mysql://localhost:3306/java2022";
    String user = "root";
    String password = "111111";

    Connection connection = DriverManager.getConnection(url, user, password);

    //执行sql语句
    Statement statement = connection.createStatement();
    String sql = "insert into student values(9,'赵云',18,'男')";
    int i = statement.executeUpdate(sql);
    System.out.println();

    System.out.println(i > 0 ? "操作成功" : "操作失败");

    //关闭资源
    connection.close();
    statement.close();
}

🌾方式五

方式五 在方式四的基础上增加配置文件, 让连接 mysql 更加灵活
在这里插入图片描述

@Test
public void test05() throws IOException, ClassNotFoundException, SQLException {
    Properties properties = new Properties();
    properties.load(new FileInputStream("src\\mysql.properties"));
    String driver = properties.getProperty("driver");
    String url = properties.getProperty("url");
    String user = properties.getProperty("user");
    String password = properties.getProperty("password");

	//加载数据库驱动
    Class.forName(driver);

	//获取数据库连接
    Connection connection = DriverManager.getConnection(url, user, password);
	//执行sql语句
    String sql = "insert into student values(10,'廉颇',18,'男')";
    int i = connection.createStatement().executeUpdate(sql);
    System.out.println(i > 0 ? "操作成功" : "操作失败");

    //关闭资源
    connection.close();
    statement.close();
}

🌱补充说明

1.MySQL驱动5.1.6及以后无需再使用Class.forName(“com.mysql.cj.jdbc.Driver”);
2.从jdk1.5以后使用了jdbc4,不再需要显示调用class.forName()注册而是自动调用驱动jar包下META-INF\services\java.sql.Driver文本中的类名称去注册。
在这里插入图片描述

3.建议写上Class.forName(“com.mysql.cj.jdbc.Driver”);,更加明确,防止低版本兼容问题。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-15 00:05:37  更:2022-04-15 00:08:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 2:46:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码