MySQL之JDBC编程

这篇具有很好参考价值的文章主要介绍了MySQL之JDBC编程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1. 数据库编程的必备条件

2. Java的数据库编程:JDBC 

3. JDBC工作原理 

4. JDBC使用 

 4.1 IDEA配置JDBC

4.2 JDBC开发案例 

4.3 JDBC使用步骤总结  

5. JDBC常用接口和类 

5.1 JDBC API 

5.2 数据库连接Connection 

5.3 Statement对象 

5.4 ResultSet对象


 

1. 数据库编程的必备条件

  • 编程语言,如 Java C C++ Python 等;
  • 数据库,如Oracle MySQL SQL Server 等;
  • 数据库驱动包:不同的数据库,对应不同的编程语言提供了不同的数据库驱动包,如:MySQL 提供了Java 的驱动包 mysql-connector-java ,要基于 Java 操作 MySQL 即需要该驱动包。同样的,要基于Java 操作 Oracle 数据库则需要 Oracle 的数据库驱动包 ojdbc  

2. Java的数据库编程:JDBC 

JDBC ,即 Java Database Connectivity java 数据库连接。 是一种用于执行SQL语句的Java API,它是Java中的数据库连接规范 。这个 API java.sql.*,javax.sql.* 包中的一些类和接口组成,它为 Java开发人员操作数据库提供了一个标准的API,可以为多种关系数据库提供统一访问。

3. JDBC工作原理 

 JDBC 为多种关系数据库提供了统一访问方式,作为特定厂商数据库访问API的一种高级抽象,它主要包含一些通用的接口类。

JDBC 访问数据库层次结构:
MySQL之JDBC编程,MySQL,mysql,数据库,java

JDBC优势:

  1. Java语言访问数据库操作完全面向抽象接口编程
  2. 开发数据库应用不用限定在特定数据库厂商的API
  3. 程序的可移植性大大增强

4. JDBC使用 

 4.1 IDEA配置JDBC

首先我们要准备数据库驱动包:

1、下载数据库驱动包

进入https://mvnrepository.com/ 这个链接,在搜索栏输入JDBC Drivers,如图:

MySQL之JDBC编程,MySQL,mysql,数据库,java

点击搜索之后,会出现如下页面,然后点击箭头所指:

MySQL之JDBC编程,MySQL,mysql,数据库,java

进去以后,会有很多的版本,选择你所需要的版本,在这里我们选择 5.1.49 版本:

MySQL之JDBC编程,MySQL,mysql,数据库,java

点进去之后,出现如下界面:

MySQL之JDBC编程,MySQL,mysql,数据库,java

点击箭头所指方框中的 .jar 文件,进行下载,下载之后无需解压。

 找到你所下载的依赖包mysql-connector-java-5.1.49.jar:

MySQL之JDBC编程,MySQL,mysql,数据库,java

找到之后选中它,进行复制(直接Ctrl+C即可)。 

 2、在项目中创建文件夹lib(右击你所创建的项目,之后如图):

MySQL之JDBC编程,MySQL,mysql,数据库,java

点击过后,出现下图,填写你要创建的文件名(lib)即可: 

MySQL之JDBC编程,MySQL,mysql,数据库,java

MySQL之JDBC编程,MySQL,mysql,数据库,java

若此处出现lib文件夹,说明创建成功。

3、将刚才复制的依赖包mysql-connector-java-5.1.49.jar粘贴(Ctrl+V)到lib中:

MySQL之JDBC编程,MySQL,mysql,数据库,java

4、右击复制过来的依赖包,在列表中选择Add as Library,点击它 

MySQL之JDBC编程,MySQL,mysql,数据库,java

5、这时这个包就可以点开了,说明配置成功

MySQL之JDBC编程,MySQL,mysql,数据库,java

4.2 JDBC开发案例 

  • 创建数据源
//1、创建数据源,描述了要操作的数据库在哪里
        DataSource dataSource = new MysqlDataSource(); //向上转型
        ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource) dataSource).setUser("root");
        ((MysqlDataSource) dataSource).setPassword("123456");

对于创建的数据源对象,所调用的三个方法:

1、setUrl方法,对于URL参数有:

MySQL之JDBC编程,MySQL,mysql,数据库,java

2、setUser方法,里面传的是用户名,一般默认为root

3、setPassword方法,里面传的是你要连接的数据库的密码

  •  建立数据库连接
 //2、和数据库服务器建立连接
        Connection connection = dataSource.getConnection();
  • 构造一个SQL语句,并转成语句对象 

以插入为例: 

String sql = "insert into student values(1,'小明')";
//需要把String str转成语句对象
PreparedStatement  statement = connection.prepareStatement(sql);
  • 执行SQL语句 
 //4、把构造好的sql发送给服务器去执行
        int n = statement.executeUpdate();
        System.out.println("n = "+n);
  • 释放资源 
//5、最后一步释放必要的资源
        statement.close();
        connection.close();

完整代码:

import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Scanner;

public class TestJDBC {
    public static void main(String[] args) throws SQLException {

        //1、创建数据源,描述了要操作的数据库在哪里
        DataSource dataSource = new MysqlDataSource(); //向上转型
        ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource) dataSource).setUser("root");
        ((MysqlDataSource) dataSource).setPassword("123456");

        //2、和数据库服务器建立连接
        Connection connection = dataSource.getConnection();

        //3、构造一个SQL
        String sql = "insert into student values(1,'小明')";

        //需要把String str转成语句对象
        PreparedStatement  statement = connection.prepareStatement(sql);

        //4、把构造好的sql发送给服务器去执行
        int n = statement.executeUpdate();
        System.out.println("n = "+n);  //执行成功,会返回一个数字

        //5、最后一步释放必要的资源
        statement.close();
        connection.close();
    }
}

若想要实现由用户自己来输入要插入的值(我们这里举的例子是插入学生的学号,姓名),代码可以这样写:

import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Scanner;

public class TestJDBC {
    public static void main(String[] args) throws SQLException {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入姓名:");
        String name = scanner.nextLine();
        System.out.println("请输入学号:");
        int id = scanner.nextInt();

        //1、创建数据源,描述了要操作的数据库在哪里
        DataSource dataSource = new MysqlDataSource(); //向上转型
        ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource) dataSource).setUser("root");
        ((MysqlDataSource) dataSource).setPassword("123456");

        //2、和数据库服务器建立连接
        Connection connection = dataSource.getConnection();

        //3、构造一个SQL
        String sql = "insert into student values(?,?)";
        //需要把String str转成语句对象
        PreparedStatement  statement = connection.prepareStatement(sql);

        statement.setInt(1,id);
        statement.setString(2,name);
        //4、把构造好的sql发送给服务器去执行
        int n = statement.executeUpdate();
        System.out.println("n = "+n);

        //5、最后一步释放必要的资源
        statement.close();
        connection.close();
    }
}

上述代码中的 ?为占位符,下标从1开始。之后可以用PreparedStatement中的setInt方法和setString方法,将用户输入的信息与其对应。

MySQL中的增删改操作都是类似的,这里只介绍了插入操作,删除和修改操作可以自己动手去试试。对于查询操作(select),他需要返回一个结果集,下面是执行查询操作SQL语句的代码:

import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

import javax.jws.soap.SOAPMessageHandlers;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class TestJDBCSelect {
    public static void main(String[] args) throws SQLException {
        DataSource dataSource = new MysqlDataSource();
        ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/java110?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource) dataSource).setUser("root");
        ((MysqlDataSource) dataSource).setPassword("123456");

        Connection connection = dataSource.getConnection();

        String sql = "select * from student";
        PreparedStatement statement = connection.prepareStatement(sql);

        ResultSet resultSet = statement.executeQuery();
        while (resultSet.next()) {
            int id = resultSet.getInt("id");
            String name = resultSet.getString("name");
            System.out.println("id: "+id);
            System.out.println("name: "+name);
        }

        //释放资源
        resultSet.close();
        statement.close();
        connection.close();
    }
}

4.3 JDBC使用步骤总结  

  1. 创建数据库连接Connection
  2. 创建操作命令Statement
  3. 使用操作命令来执行SQL
  4. 处理结果集ResultSet
  5. 释放资源

5. JDBC常用接口和类 

5.1 JDBC API 

Java JDBC 编程中对数据库的操作均使用 JDK 自带的 API 统一处理,通常与特定数据库的驱动类是完全解耦的。所以掌握Java JDBC API (位于 java.sql 包下) 即可掌握 Java 数据库编程。

5.2 数据库连接Connection 

Connection接口实现类由数据库提供,获取Connection对象通常有两种方式:

  • 一种是通过DriverManager(驱动管理类)的静态方法获取:
// 加载JDBC驱动程序
Class.forName("com.mysql.jdbc.Driver");
// 创建数据库连接
Connection connection = DriverManager.getConnection(url);
  • 一种是通过DataSource(数据源)对象获取。实际应用中会使用DataSource对象。
DataSource ds = new MysqlDataSource();
((MysqlDataSource) ds).setUrl("jdbc:mysql://localhost:3306/test");
((MysqlDataSource) ds).setUser("root");
((MysqlDataSource) ds).setPassword("root");
Connection connection = ds.getConnection();

上面我们JDBC开发案例用的就是数据源这种方式。 

  • 以上两种方式的区别是:
  1. DriverManager类来获取的Connection连接,是无法重复利用的,每次使用完以后释放资源
    时,通过connection.close()都是关闭物理连接。
  2. DataSource提供连接池的支持。连接池在初始化时将创建一定数量的数据库连接,这些连接
    是可以复用的,每次使用完数据库连接,释放资源调用connection.close()都是将
    Conncetion连接对象回收。

5.3 Statement对象 

Statement对象主要是将SQL语句发送到数据库中。JDBC API中主要提供了三种Statement对象。

 MySQL之JDBC编程,MySQL,mysql,数据库,java

实际开发中最常用的是 PreparedStatement 对象,以下对其的总结:

MySQL之JDBC编程,MySQL,mysql,数据库,java

主要掌握两种执行 SQL 的方法:
  • executeQuery() 方法执行后返回单个结果集的,通常用于select语句
  • executeUpdate()方法返回值是一个整数,指示受影响的行数,通常用于updateinsertdelete语句

5.4 ResultSet对象

ResultSet 对象它被称为结果集,它代表符合 SQL 语句条件的所有行,并且它通过一套 getXXX 方法提供了对这些行中数据的访问。ResultSet里的数据一行一行排列,每行有多个字段,并且有一个记录指针,指针所指的数据行叫做当前数据行,我们只能来操作当前的数据行。我们如果想要取得某一条记录,就要使用ResultSet next() 方法 ,如果我们想要得到ResultSet里的所有记录,就应该使用while循环。
面试问答:
1. 数据库连接有哪些方式?分别有什么区别?

 2. 数据库StatementPreparedStatement有什么区别?

 这两个问题上述内容已有答案。文章来源地址https://www.toymoban.com/news/detail-755777.html

到了这里,关于MySQL之JDBC编程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【JDBC】Java连接MySQL数据库

    数据库编程指的是通过编程语言与数据库进行交互和操作的过程,包括使用编程语言创建、连接、查询、更新和删除数据库中的数据,以及管理数据库结构和其他相关工作等。 另外,不同的数据库,对应不同的编程语言提供了不同的数据库驱动包,如:MySQL提供了Java的驱动包

    2024年02月15日
    浏览(41)
  • Java基础 - JDBC操作数据库(MySql)

    JDBC是Java语言操作数据库的一套接口,也就是规范,具体的实现需要各个数据库厂商去实现。比如我们在使用JDBC去连接mySql数据库的时候,我们必须要依赖一个叫做mysql-connector-java的jar包,这里面封装的就是mySql对于JDBC的实现。 Java中使用JDBC 首先引入mysql-connector-java依赖,比如

    2024年01月25日
    浏览(43)
  • [Java Web]JDBC->Java操作MySQL数据库

    目录 1、简介 1.1、背景 1.2、概念 1.3、驱动程序 2、JDBC的优点 3、使用步骤 3.1、操作流程 3.2、代码步骤 3.3、实例演示 3.3.1、创建空工程 3.3.2、指定项目的名称以及存放路径 3.3.3、设置项目的JDK版本和编译版本 3.3.4、创建模块 3.3.5、⭐导入MySQL驱动包 3.3.6、⭐创建Java类 4、API详

    2024年02月03日
    浏览(49)
  • Java-JDBC建立数据库连接(MySQL)

    注意:连接数据需要先在JAVA中导入mysql的jar包。 1.1—下载JAR包 1、打开浏览器搜索MySQL,进入官网 2、点击DOWNLOADS    3、点击 MySQL Community (GPL) Downloads  4、点击Connector/J 5、点击Archieve 6、选择版本,和OS,然后点击下载即可。          版本号 下载地址 8.0.32 https://download

    2024年02月03日
    浏览(50)
  • Java连接mysql数据库方法及代码(jdbc)

    编译器使用IDEA 我的相关博客: java代码程序中连接mysql数据库的方法及代码 mysql数据库并发上锁问题,java代码 1.首先从mysql官网下载mysql-connector-java.jar包到本地。 这里注意要和你本地的mysql数据库版本相匹配! 下载相应的压缩包,在本地解压即可进行下一步操作。 2.打开自己

    2024年02月08日
    浏览(48)
  • java代码实现,利用JDBC接口-连接Mysql数据库

    1、JDBC本质上是一个接口,也就是java语言操作数据库的一套API(应用程序编程接口), 接口就规则,也就是sun公司创建了一个jdbc接口,各个sql(数据库管理系统)去实现接口提供jar包。其优点JDBC不是指单一操作某一个数据库。各个厂商使用相同的接口。不同的sql厂家实现

    2024年02月09日
    浏览(51)
  • java连接mysql8.0数据库—jdbc连接

    mysql官网 点击platform Independent ,然后出现jar包选项 点download 点左下角no thanks,直接下载 原始方法,直接在项目下建一个lib包 然后将刚刚下好的zip解压,复制jar包到该目录下,右键jar包,选择add as Library 出现一堆包,表示成功导入jar包 注意:Driver类创建时,要导入com.mysql.cj.

    2024年02月13日
    浏览(45)
  • 【Java】IntelliJ IDEA使用JDBC连接MySQL数据库并写入数据

    在 IntelliJ IDEA 中连接 MySQL 数据库并将数据存储在数据表中,使用 Java 和 JDBC(Java Database Connectivity)实现。 下载并安装 IntelliJ IDEA 下载并安装 MySQL 数据库 下载 MySQL Connector/J 驱动程序(JDBC 驱动程序) 使用 Navicat 创建一个 MySQL 数据库 打开 IntelliJ IDEA。 选择 \\\"File\\\"→ “New” →

    2024年02月05日
    浏览(58)
  • java中连接数据库com.mysql.jdbc.Driver和com.mysql.cj.jdbc.Driver的区别?

    com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 是MySQL数据库连接驱动的不同版本。 com.mysql.jdbc.Driver :这是旧版的MySQL JDBC驱动(版本5.x)。它已经过时,不再推荐使用。如果您使用较旧的MySQL版本(如MySQL 5.7及以下),可以考虑使用此驱动。但请注意,该驱动在MySQL 8.0及更高版本上可

    2024年02月14日
    浏览(44)
  • java通过JDBC连接mysql8.0数据库,并对数据库中的表进行增删改查操作

    目录 一、JDBC简介 二、添加依赖 三、JDBC操作数据库的步骤 四、JDBC操作数据库——增删改查 (一)新增数据 (二)删除数据 (三)修改数据 (四)查询数据 (五)多表连接查询         Java数据库连接,(Java Database Connectivity,简称JDBC)是java语言中用来规范客户端程序如何来访问数

    2024年02月03日
    浏览(57)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包