当前位置: 首页 > news >正文

【JAVAEE】JAVA数据库连接(JDBC)

1.什么是JDBC?

Java数据库连接,(Java Database Connectivity,简称JDBC)是Java语言中用来规范客户端程序如何来访问数据库的应用程序接口,提供了诸如查询和更新数据库中数据的方法。JDBC也是Sun Microsystems的商标。我们通常说的JDBC是面向关系型数据库的。

简而言之,JDBC就是JDK提供的关于数据库操作的一套接口规范,不同数据库厂商来负责实现这个接口,完成指定的操作。

用程序和数据建立连接,分为三步骤

1.连接数据库

2.执行SQL语句

3.把查询到的结果集转换成JAVA对象

2.对于MySQL的JDBC编程的前期准备工作

知识拓展:

JAR文件(Java归档,英语:Java Archive)是一种软件包文件格式,通常用于聚合大量的Java类文件、相关的元数据和资源(文本、图片等)文件到一个文件,以便开发Java平台应用软件或库。

maven依赖是指项目对jar包的依赖。如果我们想要在工程中引入某个jar 包,只需要在pom.xml 中引入其jar 包的坐标即可。Maven 通过groupIdartifactIdversion三个向量来定位Maven 仓库其jar 包所在的位置,并把对应的jar 包引入到工程中来。

引入MySQL依赖:

打开下面这个网址:

https://mvnrepository.com/?__cf_chl_rt_tk=v38fZ3ofJLemjUxGfqXh71bR1gGKq7XXtFRXpsNsTSU-1682151712-0-gaNycGzNCuU

搜素MySQL

选择框选的这个选项。打开之后有很多版本,这里选择的是5.1.49版本。

 点击5.1.49版本。就找到了这个依赖,复制到pom.xml中

 添加完后手动点一下重新加载pom

工程栏里出现如下图内容时,表示导入成功。

3.建立连接

建立连接的五大步骤:

1加载(注册)数据库

2.连接数据库

3 执行SQL语句

4 处理结果集

5 关闭数据库,释放资源

代码实现连接:

1.连接数据库

    //先定义一个数据源对象private static DataSource dataSource=null;//连接数据库的用户名private static final String USER="root";//数据库的密码private static final String PASSWORD="111111";//数据库连接字符串private static final String URL="jdbc:mysql://127.0.0.1:3306/example?characterEncoding=utf-8&useSSL=false";

数据库连接字符串的释义如上图所示。

2.执行SQL语句

示例:根据学号查询学生信息

            // 1. 通过数据源获取一个数据库连接connection = dataSource.getConnection();// 接收用户输入的值System.out.println("请输入学号->");Scanner scanner = new Scanner(System.in);String sn = scanner.next();// 2. 定义SQL语句//String sql = "select * from student where sn = '" + sn +"'";String sql = "select * from student where sn = ?";System.out.println("sql-->" + sql);// 3. 获取statement对象//statement = connection.createStatement();// 获取一个预处理对象statement = connection.prepareStatement(sql);// 处理占位符的值statement.setString(1, sn);// 4. 执行SQLresultSet = statement.executeQuery();

3.把查询到的结果转换成Java对象

            if (resultSet.next()) {// 创建表示结果的JAVA对象Student student = new Student();// 依次读取结果集中的数据并赋值给JAVA对象student.setId(resultSet.getInt(1));student.setSn(resultSet.getString(2));student.setName(resultSet.getString(3));student.setMail(resultSet.getString(4));student.setClassesId(resultSet.getInt(5));// 打印结果System.out.println(student);}

4.释放资源

            // 依次关闭资源if (resultSet != null) {try {resultSet.close();} catch (SQLException e) {e.printStackTrace();}}if (statement != null) {try {statement.close();} catch (SQLException e) {e.printStackTrace();}}if (connection != null) {try {connection.close();} catch (SQLException e) {e.printStackTrace();}}

完整代码

package com.bitejiuyeke;import com.bitejiuyeke.model.Student;
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;import javax.sql.DataSource;
import java.sql.*;
import java.util.Scanner;/*** @Author 比特就业课* @Date 2023-04-22*/
public class Demo01_Connection {// 先定义一个数据源对象private static DataSource dataSource = null;// 数据库的用户名private static final String USER = "root";// 数据库的密码private static final String PASSWORD = "111111";// 数据库连接字符串private static final String URL = "jdbc:mysql://127.0.0.1:3306/example?characterEncoding=utf-8&useSSL=false";public static void main(String[] args) {// 1. 初化始数据源MysqlDataSource myDataSource = new MysqlDataSource();// 2. 设置连接的参数myDataSource.setURL(URL);myDataSource.setUser(USER);myDataSource.setPassword(PASSWORD);// 3. 把构建好的Mysql数据源赋值给JDBC中的datasourcedataSource = myDataSource;Connection connection = null;// 预处理对象PreparedStatement statement = null;ResultSet resultSet = null;try {// 1. 通过数据源获取一个数据库连接connection = dataSource.getConnection();// 接收用户输入的值System.out.println("请输入学号->");Scanner scanner = new Scanner(System.in);String sn = scanner.next();// 2. 定义SQL语句//String sql = "select * from student where sn = '" + sn +"'";String sql = "select * from student where sn = ?";System.out.println("sql-->" + sql);// 3. 获取statement对象//statement = connection.createStatement();// 获取一个预处理对象statement = connection.prepareStatement(sql);// 处理占位符的值statement.setString(1, sn);// 4. 执行SQLresultSet = statement.executeQuery();// 5. 解析结果集,resultSet.next()表示结果集中是否有记录if (resultSet.next()) {// 创建表示结果的JAVA对象Student student = new Student();// 依次读取结果集中的数据并赋值给JAVA对象student.setId(resultSet.getInt(1));student.setSn(resultSet.getString(2));student.setName(resultSet.getString(3));student.setMail(resultSet.getString(4));student.setClassesId(resultSet.getInt(5));// 打印结果System.out.println(student);}} catch (SQLException e) {e.printStackTrace();} finally {// 依次关闭资源if (resultSet != null) {try {resultSet.close();} catch (SQLException e) {e.printStackTrace();}}if (statement != null) {try {statement.close();} catch (SQLException e) {e.printStackTrace();}}if (connection != null) {try {connection.close();} catch (SQLException e) {e.printStackTrace();}}}}
}

http://www.lryc.cn/news/63760.html

相关文章:

  • Nestjs全网最佳翻译-概况-守卫-Guards
  • 【软考网络管理员】2023年软考网管初级常见知识考点(3)- 网络体系结构
  • javascript正则表达式大括号、中括号、小括号的作用以及应用场景
  • 5年测试老鸟总结,自动化测试的实施到落地,看这一篇足够...
  • 通达信顾比倒数线指标公式,信号不漂移
  • 网络安全: CIDR无类别路由
  • NetMQ | 发布订阅时使用含通配符的Topic
  • 行为型模式-模板方法模式
  • IPsec中IKE与ISAKMP过程分析(快速模式-消息1)
  • PostgreSQL 数据类型转换
  • 【Java笔试强训 1】
  • 你买票了吗?五一火车票发售量创历史新高,车票总发售2209万张票
  • DiffUtil的使用
  • 【Python】【进阶篇】18、Django初始化项目环境精讲
  • Web前端基础
  • ACM 1007 | 分段函数求值
  • ChatGPT技术原理 第十四章:未来发展方向
  • 大型水利投资集团,打造数智财资管理新范式
  • 【java】彻底剖析 Synchronized
  • 有反爬机制就爬不了吗?那是你还不知道反反爬,道高一尺魔高一丈啊
  • 手把手教你本地CPU环境部署清华大模型ChatGLM-6B,利用量化模型,本地即可开始智能聊天,达到ChatGPT的80%
  • FFmpeg 自定义IO CONTEXT实现音频解码,以及seek函数
  • 技能升级(2023寒假每日一题 13)
  • 低频量化之 可转债 配债数据及策略 - 全网独家
  • Code area 和Data area的区别
  • Oracle LiveLabs DB Security (数据库安全)实验汇总
  • PAT A1012 The Best Rank
  • “我和AI抠图网站的秘密情缘“
  • 最多能打多少场比赛呢
  • 鸿蒙Hi3861学习二-程序烧录与日志输出