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 访问数据库层次结构:

JDBC优势:

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

4. JDBC使用 

 4.1 IDEA配置JDBC

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

1、下载数据库驱动包

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

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

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

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

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

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

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

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

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

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

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

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

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

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参数有:

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、构造一个SQLString 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、构造一个SQLString 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对象。

 

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

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

5.4 ResultSet对象

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

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

 这两个问题上述内容已有答案。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/155064.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电脑便签功能在哪里找?电脑桌面便签怎么添加?

很多上班族在使用电脑办公的时候,都需要随手记录工作事项,例如记录共同工作时的想法、会议笔记、常用工作资料、每天待办的工作任务等事项,这时候使用纸质的笔记本来记录工作,不仅不方便随时查看和使用,而且在修改、删…

HarmonyOS ArkTSTabs组件的使用(六)

Tabs组件的使用 ArkUI开发框架提供了一种页签容器组件Tabs,开发者通过Tabs组件可以很容易的实现内容视图的切换。页签容器Tabs的形式多种多样,不同的页面设计页签不一样,可以把页签设置在底部、顶部或者侧边。 Tabs组件的简单使用 Tabs组件…

报错注入 [极客大挑战 2019]HardSQL1

打开题目 输入1或者1",页面均回显NO,Wrong username password!!! 那我们输入1 试试万能密码 1 or 11 # 输入1 and 12 # 输入1 union select 1,2,3 # 输入1 ununionion seselectlect 1,2,3 # 输入1 # 输入1# 页面依旧回…

mac 和 windows 相互传输文件【共享文件夹】

文章目录 前言创建共享文件夹mac 连接共享文件夹 前言 温馨提示:mac 电脑和 windows 电脑必须处于同一局域网下 本文根据创建共享文件夹的方式实现文件互相传输,所以两台电脑必须处于同一网络 windows 创建共享文件夹,mac 电脑通过 windows…

C++11新特性 变参模板、完美转发和emplace

#include <iostream> #include <vector> #include <deque> #include <list> #include <algorithm> using namespace std;class student { public:student() {cout << "无参构造函数被调用!" << endl;}student(int age, st…

PyQt(学习笔记)

学习资料来源&#xff1a; PyQt快速入门——b站王铭东老师 PyQt官网的所有模块 C具体实现的官方文档 PyQt&#xff08;学习笔记&#xff09; PyCharm环境准备运行第一个程序QPushButtonQLabelQLineEdit调整窗口大小、位置、图标布局信号与槽PyQt引入多线程 PyCharm环境准备 新…

yum 搭建仓库 http/ftp

目录 http ftp http 服务端 1. 下载 httpd 服务&#xff0c;记得将防火墙和安全终端全部关掉 2. 开启 httpd 服务 3. 临时挂载 客户端 1. 下载 httpd 服务&#xff0c;记得将防火墙和安全终端全部关掉 2. 开启 httpd 服务 3. 进入 /etc/yum.repos.d 4. 新建一个目录 mhy&…

新零售数字化系统提供商怎么选择?2023十大收银系统排行榜-亿发

随着零售业务的日益繁荣和电子商务的迅猛发展&#xff0c;零售收银系统已成为各类商家提高效率、管理库存、提供更好服务的不可或缺的工具。然而&#xff0c;在众多的收银系统中&#xff0c;如何选择一款适合自己的&#xff0c;一直是许多商家头疼的问题。今天我们就来盘点一下…

用Auth Analyzer插件批量测试接口越权,安全测试快人一步!

随着信息化技术的不断发展&#xff0c;软件安全成了软件行业的重大挑战&#xff0c;因此安全测试也成为了测试人员必备的技能之一。 沐沐在安全测试过程中较为常见的就是接口越权漏洞&#xff0c;在尝试过多种工具进行越权漏洞测试后&#xff0c;最终找到了个人认为最便捷最有…

java springboot 监控线程池的状态

Autowiredprivate Executor personInfoTaskExecutor;/*** 监控线程池状态* return*/GetMapping("asyncExceutorInfo")public Map getThreadInfo() {Map map new HashMap();Object[] myThread {personInfoTaskExecutor};for (Object thread : myThread) {ThreadPoolT…

Git教程1:生成和提交SSH公钥到远程仓库

要生成 Git 的公钥并将其提交到远程仓库&#xff0c;你可以按照以下步骤进行操作&#xff1a; 打开命令行终端&#xff0c;并确保已经安装了 Git。在终端中输入以下命令来生成 SSH 密钥对&#xff1a;ssh-keygen -t rsa -b 4096 -C "your_emailexample.com"这将生成…

网络连接Android设备

参考&#xff1a;https://blog.csdn.net/qq_37858386/article/details/123755700 二、网络adb调试开启步骤 1、把Android平板或者手机WiFi连接到跟PC机子同一个网段的网络&#xff0c;在设置-系统-关于-状态 下面查看设备IP,然后查看PC是否可以ping通手机的设备的IP。 2、先…

[ 加密 ] SHA256

SHA256 例程 一般文件的完整性要使用md5或者sha进行完整性校验&#xff0c;这里提供两个函数&#xff0c; intact_update_sha 是计算指定文件SHA值并保存到SHA文件 intact_check_sha 计算文件SHA值并和SHA文件进行对比 编译方法&#xff1a; gcc demo.c -lssl -lcrypto #…

【运维日常】lvm中的lv是如何扩容的---直接干

本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》&#xff1a;python零基础入门学习 《python运维脚本》&#xff1a; python运维脚本实践 《shell》&#xff1a;shell学习 《terraform》持续更新中&#xff1a;terraform_Aws学习零基础入门到最佳实战 《k8…

ansible练习题1

安装并配置ansible 在控制节点上安装并配置Ansible,要求如下: | 安装所需的软件包: 创建静态inventory文件/home/student/ansible/inventory ,要求如下: servera属于dev主机组 serverb属于test和balancers主机组 serverc和serverd属于prod主机组 …

springboot上传文件

Content-Type只能用form-data 另外请求体不能包好几层&#xff0c;可以用一个实体类接收 示例&#xff1a; public class UploadFileDTO {private MultipartFile file; }也可以直接用 MultipartFile file接收; 也可以加注解RequestParam 不能加RequestBody注解

14.Oracle中的事务

oracle的事务管理 一、什么是事务二、事务的基本操作1、事务的开始与结束2、事务处理的案例2.1题目12.2题目2 一、什么是事务 Oracle 11g是一个关系型数据库管理系统&#xff0c;它提供了强大的事务管理功能&#xff0c;可以确保数据库操作的一致性、可靠性和持久性。事务是数…

MAVEN——PACKAGE、INSTALL、DEPLOY的联系与区别

我们在用maven构建java项目时&#xff0c;最常用的打包命令有mvn package、mvn install、deploy&#xff0c;这三个命令都可完成打jar包或war&#xff08;当然也可以是其它形式的包&#xff09;的功能&#xff0c;但这三个命令还是有区别的。下面通过分别执行这三个命令的输出结…

【rust:tauri-app踩坑记录】dangerousRemoteDomainIpcAccess 不适用于IP地址,临时解决方案

找到一个临时解决方案&#xff1a; 修改依赖包的源代码 找到 C:\Users%USER_HOME%.cargo\registry\src\index.crates.io-6f17d22bba15001f\tauri-1.4.1\src\scope\ipc.rs 修改 函数 remote_access_for 将 155 行中的 matches_domain 删除掉&#xff0c;去掉校验 if matches_w…

数据仓库及ETL的理论基础

数据仓库&#xff08;Data Warehouse&#xff09;是一个用于存储和管理大量结构化数据的系统&#xff0c;旨在支持企业的决策制定过程。它是一个集成的、主题导向的、时间变化的、非易失性的数据集合&#xff0c;用于支持企业的决策制定过程。数据仓库的设计目标是提供高性能的…