Java JDBC使用入门讲解

 更新时间:2022年12月08日 10:18:39   作者:-BoBooY-  
JDBC是指Java数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库。从根本上来说,JDBC 是一种规范,它提供了一套完整的接口,允许便携式访问到底层数据库,本篇文章我们来了解MySQL连接JDBC的流程方法

前言:本节我们开始学习JDBC,JDBC的基础对于我们开发来说非常的重要,大家一定要重视起来!

*.学习目标

  • 掌握JDBC的的CRUD
  • 理解JDBC中各个对象的作用
  • 掌握Druid的使用

1、JDBC概述

在开发中我们使用的是java语言,那么势必要通过java语言操作数据库中的数据。这就是接下来要学习的JDBC。

1.1、JDBC的概念

JDBC 就是使用Java语言操作关系型数据库的一套API

全称:( Java DataBase Connectivity ) Java 数据库连接

我们开发的同一套Java代码是无法操作不同的关系型数据库,因为每一个关系型数据库的底层实现细节都不一样。如果这样,问题就很大了,在公司中可以在开发阶段使用的是MySQL数据库,而上线时公司最终选用oracle数据库,我们就需要对代码进行大批量修改,这显然并不是我们想看到的。我们要做到的是同一套Java代码操作不同的关系型数据库,而此时sun公司就指定了一套标准接口(JDBC),JDBC中定义了所有操作关系型数据库的规则。众所周知接口是无法直接使用的,我们需要使用接口的实现类,而这套实现类(称之为:驱动)就由各自的数据库厂商给出。

1.2、JDBC的本质

  • 官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口
  • 各个数据库厂商去实现这套接口,提供数据库驱动jar包
  • 我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类

1.3、JDBC的好处

  • 各数据库厂商使用相同的接口,Java代码不需要针对不同数据库分别开发
  • 可随时替换底层数据库,访问数据库的Java代码基本不变

以后编写操作数据库的代码只需要面向JDBC(接口),操作哪儿个关系型数据库就需要导入该数据库的驱动包,如需要操作MySQL数据库,就需要再项目中导入MySQL数据库的驱动包。如下图就是MySQL驱动包

2、JDBC快速入门

Java操作数据库的流程

(1)编写Java代码

(2)Java代码将SQL发送到MySQL服务端

(3)MySQL服务端接收到SQL语句并执行该SQL语句

(4)将SQL语句执行的结果返回给Java代码

2.1、编写代码

创建工程,导入驱动jar包

注册驱动

Class.forName("com.mysql.jdbc.Driver");

获取连接

Java代码需要发送SQL给MySQL服务端,就需要先建立连接

Connection conn = DriverManager.getConnection(url,username,password);

定义SQL语句

String sql = “update…” ;

获取执行SQL对象

执行SQL语句需要SQL执行对象,而这个执行对象就是Statement对象

Statement stmt = conn.createStatement();

执行SQL

stmt.executeUpdate(sql); 

处理返回结果

释放资源

stmt.close();
conn.close();

2.2、完整案例

新建一个空项目

新建模块

导入驱动包

在添加为库文件的时候,有如下三个选项

  • Global Library :全局有效
  • Project Library :项目有效
  • Module Library :模块有效

创建JdbcDemo类并编写如下代码:

package com.bby;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
public class JdbcDemo {
    public static void main(String[] args) throws Exception {
        //1. 注册驱动
        Class.forName("com.mysql.jdbc.Driver");
        //2.获取连接
        String url = "jdbc:mysql://localhost:3306/jdbc";
        String username = "root";
        String password = "1234";
        Connection connection = DriverManager.getConnection(url,username,password);
        //3.定义sql语句
        String sql = "update acount set money = 1000 where id = 1";
        //4.获取执行sql对象Statement
        Statement statement = connection.createStatement();
        //5.执行sql
        int count = statement.executeUpdate(sql);
        //6.处理结果
        System.out.println(count);
        //7.释放资源
        statement.close();
        connection.close();
    }
}

查看控制台结果

数据库数据更新前

数据库数据更新后

To be continued…

到此这篇关于Java JDBC使用入门讲解的文章就介绍到这了,更多相关Java JDBC内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java8 利用reduce实现将列表中的多个元素的属性求和并返回操作

    java8 利用reduce实现将列表中的多个元素的属性求和并返回操作

    这篇文章主要介绍了java8 利用reduce实现将列表中的多个元素的属性求和并返回操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • Hadoop中的压缩与解压缩案例详解

    Hadoop中的压缩与解压缩案例详解

    压缩就是通过某种技术(算法)把原始文件变下,相应的解压就是把压缩后的文件变成原始文件,本文给大家分享Hadoop中的压缩知识,感兴趣的朋友跟随小编一起看看吧
    2021-12-12
  • Spring AOP底层机制之代理模式

    Spring AOP底层机制之代理模式

    如何实现在不修改源码的基础上实现代码功能的增强呢?spring为我们提供了代理模式。所谓的代理模式通俗来说就是一个中介,它给某一个对象提供一个代理对象,并由代理对象控制原对象的引用,从而实现在不修改源码的基础上实现代码功能的增强
    2022-08-08
  • Spring populateBean属性赋值和自动注入

    Spring populateBean属性赋值和自动注入

    这篇文章主要为大家介绍了Spring populateBean属性赋值和自动注入示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • java:无法访问org.springframework.boot.SpringApplication问题

    java:无法访问org.springframework.boot.SpringApplication问题

    这篇文章主要介绍了java:无法访问org.springframework.boot.SpringApplication问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • 解决使用ProcessBuilder踩到的坑及注意事项

    解决使用ProcessBuilder踩到的坑及注意事项

    这篇文章主要介绍了解决使用ProcessBuilder踩到的坑,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java中 this和super的用法与区别小结

    Java中 this和super的用法与区别小结

    在Java的学习与开发者我们经常遇到this和super关键字,本文主要介绍了Java中 this和super的用法与区别小结,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • JavaWeb文件下载功能实例代码

    JavaWeb文件下载功能实例代码

    这篇文章主要为大家详细介绍了JavaWeb文件下载功能实例代码,代码简单实用,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • 详解高性能缓存Caffeine原理及实战

    详解高性能缓存Caffeine原理及实战

    Caffeine是基于Java 8开发的,提供了近乎最佳命中率的高性能本地缓存组件,Spring5开始不再支持Guava Cache,改为使用Caffeine。Caffeine提供的内存缓存使用参考Google guava的API
    2021-06-06
  • SpringBoot中的@PreAuthorize注解详解

    SpringBoot中的@PreAuthorize注解详解

    这篇文章主要介绍了SpringBoot中的@PreAuthorize注解详解,@PreAuthorize注解会在方法执行前进行权限验证,支持Spring EL表达式,它是基于方法注解的权限解决方案,需要的朋友可以参考下
    2023-09-09

最新评论