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;最终找到了个人认为最便捷最有…

网络连接Android设备

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

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

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

重磅解读 | 阿里云 云网络领域关键技术创新

云布道师 10 月 31 日&#xff0c;杭州云栖大会&#xff0c;阿里云技术主论坛带来了一场关于阿里云主力产品与技术创新的深度解读&#xff0c;阿里云网络产品线负责人祝顺民带来《云智创新&#xff0c;网络随行》的主题发言&#xff0c;针对阿里云飞天洛神云网络&#xff08;下…

PostgreSQL按月计算每天值的累加

要按月计算每天值的累加&#xff0c;您可以使用PostgreSQL中的日期函数和窗口函数。下面是一个示例查询&#xff0c;假设您有一个名为"table_name"的表&#xff0c;其中包含一个日期列"date_column"和一个数值列"value_column"&#xff1a; SELE…

spark内置数据类型

在用scala编写spark的时候&#xff0c;假如我现在需要将我spark读的数据源的字段&#xff0c;做一个类型转换&#xff0c;因 为需求中要拼接出sql的create table语句&#xff0c;需要每个字段的sql中的类型&#xff0c;那么就需要去和sparksql 中的内置数据类型去比对。 写s…

丐版设备互联方案:安卓linux互联局域网投屏,文件共享,共享剪切板

华为&#xff0c;苹果&#xff0c;甚至小米最近也推出了澎湃&#xff2f;&#xff33;&#xff0c;发现实在是太方便了&#xff0c;当然这些对硬件&#xff0c;系统的要求还是比较高&#xff0c;我用的主力机是小米&#xff11;&#xff12;pro和ubuntu&#xff0c;win双系统也…

数据库mysql详细教学

目录 mysql的第一组基本操作&#xff1a;数据库操作 1、查看当前数据库 2、创建数据库 3、选中数据库 4、删除数据库 5、表操作 5.1查看数据库中的表 ​编辑 5.2创建表 5.2.1数据类型 5.3 查看指定表的表结构 5.4删除表 5.5 MySQL表的增删改查 5.5.1新增 / 插入数据…

uview-plus中二级菜单左右联动更改为uni-app+vue3+vite写法

uview-plus3.0重磅发布&#xff0c;全面的Vue3移动组件库 该插件使用的vue2写法&#xff0c;但支持vue3引用&#xff0c;在此基础上修改为uni-appvue3vite; <template><view class"u-wrap mainClass"><!-- <back-header :title"pageTitle&quo…

太累了,是时候让AI数字人来帮我干活了(走,上教程)

阿酷TONY&#xff0c;原创文章&#xff0c;长沙&#xff0c;2023.11.21 关 键 词&#xff1a;AI数字人&#xff0c;生成式AI&#xff0c;智能数字分身适用场景&#xff1a;培训数字人&#xff0c;演讲授课数字人&#xff0c;直播带货数字人特别说明&#xff1a;教程用的是国内…

捷诚管理信息系统 SQL注入漏洞复现

0x01 产品简介 捷诚管理信息系统是一款功能全面&#xff0c;可以支持自营、联营到外柜租赁的管理&#xff0c;其自身带工作流管理工具&#xff0c;能够帮助企业有效的开展内部审批工作。 0x02 漏洞概述 捷诚管理信息系统CWSFinanceCommon.asmx接口存在SQL注入漏洞。未经身份认…

【UE】线框材质

一、方式1 新建一个材质&#xff0c;混合模式设置为“已遮罩”&#xff0c;勾选“双面” 勾选“线框” 然后可以随便给一个自发光颜色&#xff0c;这样最基本的线框材质就完成了 二、方式2 新建一个材质&#xff0c;混合模式设置为“已遮罩”&#xff0c;勾选“双面”&#x…