java之路 —— 连接数据库知识与操作应用

这篇具有很好参考价值的文章主要介绍了java之路 —— 连接数据库知识与操作应用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

java如何连接数据库,java,数据库,java,mybatis


前言

项目很多小伙伴学习后端的时候以及学习数据库的时候,在后端程序中,有很多的数据来自前端的传递或者后端本身创建的,这些数据都是需要的,学过数据库的小伙伴知道,数据存放到数据库里才容易管理以及安全、方便。那么我们就会需要将程序与数据库进行连接并执行相关的操作,这是后端的一项经典又必不可少的技术


java如何连接数据库,java,数据库,java,mybatis

一、java连接数据库技术

Java 连接技术是 Java 程序与外部资源进行交互的方式,可以包括连接数据库、连接消息队列、连接 Web 服务等等。

Java 连接技术主要有以下几种:

1.JDBC

JDBC(Java Database Connectivity):JDBC是Java连接数据库的标准API。它提供了一组接口和类,用于与关系型数据库进行交互。通过JDBC,可以连接到各种数据库(如MySQL、Oracle、SQL Server等),执行SQL语句、事务管理和结果集处理等操作。

2.ORM

ORM框架: ORM(Object-Relational Mapping)框架允许将Java对象和关系型数据库之间进行映射,进而实现数据库操作。常见的Java ORM框架包括Hibernate、MyBatis等。这些框架提供了对象与数据库表之间的映射关系配置,简化了数据库操作的编写和维护工作。
3.JPA
JPA(Java Persistence API): JPA是一种基于ORM思想的Java持久化规范。它提供了一组API,用于管理和持久化Java对象到关系型数据库。JPA具有统一的API和查询语言,可以与多种底层ORM实现(如Hibernate、EclipseLink等)集成。
4.JPA
数据库连接池: 数据库连接池是一种管理数据库连接的技术,它通过创建和维护一定数量的数据库连接对象,实现连接的复用和高效管理。常见的Java数据库连接池有Apache Commons DBCP、C3P0和HikariCP等。
5.NoSQL数据库驱动:
NoSQL数据库驱动: 除了关系型数据库,Java也支持连接和操作各种NoSQL数据库,如MongoDB、Redis、Elasticsearch等。这些数据库通常有自己的原生Java驱动或客户端库,用于在Java应用程序中进行连接和数据交互。

二、jdbc

JDBC是Java语言中提供的一组API,它提供了一种与关系型数据库进行交互的标准方式。利用JDBC可以让Java程序连接到各种不同的关系型数据库(例如Oracle、MySQL、Microsoft SQL Server等),执行SQL语句以及检索和更新数据库中的数据。

JDBC API包含两部分:JDBC API和JDBC驱动程序
JDBC API提供了访问关系型数据库的标准方式,其中包含连接数据库所需的类、接口和标准SQL类型。
JDBC驱动程序是一个具体的实现,不同类型的关系型数据库需要不同的驱动程序实现。

在使用JDBC时,我们需要先加载对应的JDBC驱动程序,然后通过JDBC API提供的接口和类建立数据库连接,最后通过执行SQL语句来操作数据库中的数据,执行结束后需关闭连接。下面是一个简单的Java程序示例,展示如何使用JDBC连接数据库并执行SQL语句:

import java.sql.*;

public class JDBCDemo {

    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        ResultSet rs = null;

        try {
            // 加载MySQL驱动程序
            Class.forName("com.mysql.jdbc.Driver");

            // 获取数据库连接
            String url = "jdbc:mysql://localhost:3306/test?useSSL=false";
            String user = "root";
            String password = "123456";
            conn = DriverManager.getConnection(url, user, password);
           /**
            准备写入 SQL 
           */
            // 创建Statement对象
            stmt = conn.createStatement();

            // 执行SQL查询语句
            rs = stmt.executeQuery("SELECT * FROM student");

            // 处理查询结果
            while (rs.next()) {
                System.out.println(rs.getString("Studentname")); //获取Studentname这一列的数据
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } finally {
            // 关闭ResultSet、Statement和Connection
            try {
                if (rs != null) {
                    rs.close();
                }
                if (stmt != null) {
                    stmt.close();
                }
                if (conn != null) {
                    conn.close();
                }
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}

上面的示例程序中,我们首先加载了MySQL数据库的JDBC驱动,然后通过DriverManager获取数据库连接,创建Statement对象并执行SQL查询语句,最后处理查询结果并关闭所持有的JDBC资源。

三、连接步骤

使用 JDBC 连接数据库需要分为以下几个步骤:

1. 加载数据库驱动

在连接数据库之前,需要先加载相应的 JDBC 驱动程序。不同类型的数据库需要使用不同的驱动程序,例如 MySQL 使用的驱动程序是 com.mysql.jdbc.Driver,Oracle 使用的是 oracle.jdbc.driver.OracleDriver,如果忘记加载驱动程序,会导致连接数据库失败。

加载驱动程序可以通过 Class.forName() 方法实现,例如:

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

2. 创建数据库连接

在加载完成驱动程序之后,就可以使用 DriverManager.getConnection() 方法来创建连接对象。该方法需要传递一个包含连接信息的 URL(Uniform Resource Locator)、用户名和密码,例如:

String url = "jdbc:mysql://localhost:3306/mydatabase";
String user = "root";
String password = "mypassword";
Connection conn = DriverManager.getConnection(url, user, password);

其中,“jdbc:mysql://” 表示连接的数据库类型是 MySQL,“localhost” 表示连接到本地主机,“3306” 表示连接到 MySQL 的端口号,“mydatabase” 表示要连接的数据库名称,“root” 和 “mypassword” 分别表示连接用户名和密码。

3. 创建 Statement 或 PreparedStatement 对象

连接数据库之后,可以使用 Statement 或 PreparedStatement 对象执行 SQL 语句。其中,Statement 对象用于执行静态 SQL 语句或者预编译的 SQL 语句,PreparedStatement 对象用于执行带参数的 SQL 语句。

创建 Statement 或 PreparedStatement 对象可以通过 Connection 的 createStatement() 或 prepareStatement() 方法实现,例如:

// 创建 Statement 对象
Statement stmt = conn.createStatement();
// 创建 PreparedStatement 对象
PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM user WHERE username = ?");

4. 执行 SQL 语句

创建好 Statement 或 PreparedStatement 对象之后,就可以使用 execute()、executeQuery() 或 executeUpdate() 方法来执行 SQL 语句了。其中,execute() 用于执行任意一种 SQL 语句,executeQuery() 用于执行 SELECT 语句并返回结果集,executeUpdate() 用于执行 INSERT、UPDATE 和 DELETE 语句并返回受影响的记录数。

// 执行查询语句,返回结果集
ResultSet rs = stmt.executeQuery("SELECT * FROM user");
// 执行插入语句,返回受影响的记录数
int count = stmt.executeUpdate("INSERT INTO user (username, password) VALUES ('admin', '123456')");

5. 处理结果集

执行 SQL 语句之后,需要将结果集通过 ResultSet 对象进行获取。ResultSet 对象的使用方法和 Statement 或 PreparedStatement 对象类似,例如可以使用 next() 方法将当前记录移动到下一条记录,使用 getXXX() 获取记录中某个列的值,例如:

while (rs.next()) {
    int id = rs.getInt("id");
    String username = rs.getString("username");
    String password = rs.getString("password");
}

6. 关闭资源

最后,在不再使用数据库连接、Statement、PreparedStatement 或 ResultSet 对象时,需要将它们及时关闭,释放对数据库系统的连接,以减少系统负担。例如:

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

以上就是使用 JDBC 连接到数据库并执行 SQL 语句的基本步骤。需要注意的是,使用 JDBC 连接数据库需要加上异常处理,防止在执行过程中出现异常导致程序崩溃。文章来源地址https://www.toymoban.com/news/detail-773185.html

到了这里,关于java之路 —— 连接数据库知识与操作应用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • java通过JDBC连接mysql8.0数据库,并对数据库中的表进行增删改查操作

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

    2024年02月03日
    浏览(51)
  • 【数据库通关之路】 MySQL 全路线学习知识点梳理(中)

    本文是 MYSQL零基础小白学习 系列的第二篇文章,点此阅读 上一篇文章 文末包邮送《分布式中间件核心原理与RocketMQ最佳实践 》 (点击下方目录直达)一本,本文每+1000浏览额外加抽一人 需求 :设计包含如下信息的学生表,请注重数据类型、长度的合理性。 编号 姓名,姓名最

    2023年04月20日
    浏览(27)
  • 【数据库通关之路】 MySQL 全路线学习知识点梳理(下)

    本文是MYSQL零基础小白学习系列的第三篇文章,点此阅读 上一篇文章 文末 包邮随机送《MySQL数据库进阶实战 》 五本 (点击下方目录直达) 目的:主键是一行数据的唯一标识,要求非空且唯一 添加约束: 建完表后添加主键约束: 删除约束: 目的:保存数据时,未指定值则采

    2024年02月04日
    浏览(34)
  • 【数据库通关之路】 MySQL 全路线学习知识点梳理(上)

    这是一篇 MySQL 通关 硬核经验学习路线,包括数据库相关知识,SQL语句的使用,数据库约束,设计等。专为小白整理,针对数据库零基础的朋友们,手把手带你学习MySQL,让你轻松学会! 文末包邮送《WPS Office高效办公:数据处理与分析 》1本(点击下方目录直达),本文每+1000浏览

    2024年02月04日
    浏览(29)
  • 从小白到大神之路之学习运维第37天---第三阶段---mysql数据库之拓展知识

    拓展知识 目录 一、MySQL数据库目录结构以及存放位置 二、MySQL Enterprise Backup 三、MySQL读写分离器 四、进程和线程 五、CentOS 7 中配置静态 IP     1. 数据库存储目录: MySQL数据库的数据文件存储在指定的数据目录下。MySQL安装时默认数据目录在Linux系统中为/var/lib/mysql,Windows系

    2024年02月08日
    浏览(35)
  • Python之数据库操作(连接数据库,增删改查操作,易错点理解)

    文章目录 前言 一、Python之数据库操作 二、 pymysql 安装 三、pymysql 包引入  连接数据库 创建游标 执行sql数据 - 增删改查 要获取查询结果数据 关闭游标,关闭数据库连接 总结 记录:Python操作数据库的步骤,不容易理解的地方。 学习地址: python与各大数据库的连接: http:/

    2023年04月16日
    浏览(38)
  • MySQL数据库,JDBC连接数据库操作流程详细介绍

    在学完 MySQL 和 Java 后,我们通常会尝试使用 Java编译器 连接 MySQL数据库,从而达到使用编译器来操作数据库的效果。连接的这个过程会用 JDBC 相关知识,因此我把 JDBC 包的下载及导入流程,以及 JDBC 的使用流程整理下来分享给大家。 目录 1. 啥是JDBC? 2. JDBC依赖包 2.1 依赖包

    2024年02月06日
    浏览(75)
  • PHP连接并操作数据库

    (如果有环境请直接跳过,阅读下面的操作) 在Linux中进行PHP和数据库的环境搭建(适用于CentOS-7.0版本或以上),以下操作全部是在 root 用户中操作,普通用户中记得命令前加入 sudo 进行提权后进行操作。 1、安装数据库 2、配置数据库 可以用这个手动设置密码,防止空密码登

    2024年02月05日
    浏览(38)
  • python与数据库连接操作

    下载命令: pip install PyMySQL 一般我们会使用镜像下载,这样会比较快,比如清华镜像: pip install pymysql -i https://pypi.tuna.tsinghua.edu.cn/simple 连接数据库之前,我们需要知道自己需要连接数据库的用户名,密码,数据库名等信息 步骤: 连接connect() 创建cursor()对象 使用excute()执行S

    2024年02月08日
    浏览(34)
  • eclipse连接mysql数据库操作

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 目录 前言 一、mysql数据库 二、eclipse项目里要有数据库jar包 1.下载或直接使用已有mysql-connection的jar包 2.eclipse加上MySQL 连接 3.项目执行sql文件 总结 使用eclipse的sql文件实现数据库数据创建 提示

    2024年02月04日
    浏览(26)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包