Java程序操作数据库——JDBC

JDBC

想要通过Java程序操作关系型数据库,就需要使用JDBC(Java DataBase Connectivity),JDBC就是使用Java程序操作关系型数据库的一套API(Java官方提供的)。很多高级的操作数据库的框架(如MyBatis、MyBatisPlus等)底层都是基于JDBC的,是对JDBC的高级封装;所以说了解原生的JDBC的操作是十分重要的。

Java官方只是提供了JDBC的规范(接口),并没有对其进行实现,而是将JDBC的实现交给了各个数据库厂商(如MySQL,Oracle等),因为各个不同的关系型数据库的底层细节是各个厂商最清楚的。各个厂商提供的JDBC实现也被称为数据库驱动,我们在使用JDBC的时候需要根据数据库类型,引入厂商实现的jar包。

快速入门

1.准备工作:创建Maven项目,根据使用的数据库,在pom.xml引入对应厂商的数据库驱动(不同厂商对于JDBC的实现)依赖,并且准备一个数据库表用于操作。 2.编写JDBC程序,操作数据库表。

准备

因为用的是Maven构建项目,直接引入mysql实现的JDBC的坐标即可

数据库建表、数据:

create table user(id int unsigned primary key auto_increment comment 'ID,主键',username varchar(20) comment '用户名',password varchar(32) comment '密码',name varchar(10) comment '姓名',age tinyint unsigned comment '年龄'
) comment '用户表';insert into user(id, username, password, name, age) values (1, 'daqiao', '123456', '大乔', 22),(2, 'xiaoqiao', '123456', '小乔', 18),(3, 'diaochan', '123456', '貂蝉', 24),(4, 'lvbu', '123456', '吕布', 28),(5, 'zhaoyun', '12345678', '赵云', 27);

JDBC实现DQL语句

编写代码,操作数据库表,实现对数据的更改(此处更新id为1的用户的年龄)

package com.wzb;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;public class JDBCQuickStart {public static void main(String[] args) throws ClassNotFoundException, SQLException {// 注册驱动,本质上是将驱动类加载到内存中,这一步是为了告诉程序用的是什么数据库Class.forName("com.mysql.cj.jdbc.Driver");// 获取数据库连接String url = "jdbc:mysql://localhost:3306/db01";String username = "root";String password = "123456";Connection connection = DriverManager.getConnection(url, username, password);// 获取SQL语句执行对象Statement statement = connection.createStatement();// 在SQL语句执行对象中执行SQL语句     statement:声明、报告、语句     execute:执行、实施statement.executeUpdate("update user set age = 20 where id = 1");// 处理完成后释放资源statement.close();connection.close();}
}

 

运行代码,发现数据成功被更改了。

增删改在数据库的操作中都是属于DML语句,都可以使用Statement类中的executeUpdate方法,在方法中书写SQL语句从而达到修改的目的,而数据库中的DQL(查询语句)则不属于executeUpdate中的类别,DQL属于executeQuery,需要使用executeQuery方法进行查询。

JDBC实现DQL语句

在Java程序中对数据库进行查询操作,一般是为了将查询到的数据封装为对象,便于后续处理和响应前端,封装成对象时,对象的属性必须和数据库中的字段完全一致:

package com.wzb;import com.wzb.pojo.User;
import org.junit.Test;import java.sql.*;/*** JDBC查询数据库的用户信息并封装到User对象中*/
public class JDBCQueryTest {@Testpublic void query() throws ClassNotFoundException, SQLException {String url = "jdbc:mysql://localhost:3306/db01";String username = "root";String password = "123456";// 注册驱动Class.forName("com.mysql.cj.jdbc.Driver");// 创建连接Connection connection = DriverManager.getConnection(url, username, password);String sql = "select id, username, password, name, age from user where username = ? and password = ?";// 这是预编译的SQLPreparedStatement statement = connection.prepareStatement(sql);// 通过Statement中的setString来对预编译的SQL中的占位符进行赋值statement.setString(1, "daqiao");statement.setString(2, "123456");// 得到查询的集合ResultSetResultSet resultSet = statement.executeQuery();// 遍历结果集合并进行封装while (resultSet.next()) {User user = new User(resultSet.getInt("id"),resultSet.getString("username"),resultSet.getString("password"),resultSet.getString("name"),resultSet.getInt("age"));System.out.println(user);};// 释放资源statement.close();connection.close();}
}

成功查询并封装为User实体对象:

 

 

 

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

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

相关文章

nfc中继测试

简述: 像NFC钥匙的中继是比较简单的,我们需要准备的工具是两台手机,然后需要一个服务端。在手机上安装工具NFC gate,通过这个工具就可以针对NFC进行中继。只要一个手机靠近NFC卡片钥匙,另外一个手机贴住车门就可以实现…

STM32--MAP文件

C语言源代码到目标文件的分析过程: 预处理操作:执行宏替换、条件编译以及包含指定的文件 hello.i:预处理后文件 编译:进行机器翻译产出 hello.s:汇编文件 hello.o:可重定位目标文件(机器码文件&…

UPLOAD LABS | UPLOAD LABS 靶场初识

关注这个靶场的其它相关笔记:UPLOAD LABS —— 靶场笔记合集-CSDN博客 0x01:UPLOAD LABS 靶场简介 UPLOAD LABS 靶场是一个专门用于学习文件上传漏洞攻击和防御的靶场。它提供了一系列文件上传漏洞的实验环境,用于帮助用户了解文件上传漏洞的…

基于米尔全志T527开发板的FacenetPytorch人脸识别方案

本篇测评由优秀测评者“小火苗”提供。 本文将介绍基于米尔电子MYD-LT527开发板(米尔基于全志 T527开发板)的FacenetPytorch人脸识别方案测试。 一、facenet_pytorch算法实现人脸识别 深度神经网络 1.简介 Facenet-PyTorch 是一个基于 PyTorch 框架实…

基于智能物联网关的车辆超重AI检测应用

超重超载是严重的交通违法行为,超重超载车辆的交通安全风险极高,像是一颗行走的“不定时炸弹”,威胁着社会公众的安全。但总有一些人受到利益驱使,使超重超载的违法违规行为时有发生。 随着物联网和AI技术的发展,针对预…

scala的守卫语句格式

import scala.io.StdIn object test49{//从控制台读入一个数字a,使用&#xff08;StdIn.readInt&#xff09;//如果a>0并且a<3,打印[0-3]//如果a>4并且a<8,打印[4-8]//否则:打印未匹配 // def main(args: Array[String]): Unit { // val aStdIn.readInt()//等…

数组和链表OJ题

leetcode用编译器调试的技巧 数组和链表练习题 leetcode/reverse_Link/main.c Hera_Yc/bit_C_学习 - 码云 - 开源中国 1、移除元素 ​​​​​​27. 移除元素 - 力扣&#xff08;LeetCode&#xff09; int removeElement(int* nums, int numsSize, int val) {int src 0, …

Scala—数组(不可变数组Array、可变数组ArrayBuffer)用法详解

Scala集合概述-链接 大家可以点击上方链接&#xff0c;先对Scala的集合有一个整体的概念&#x1f923;&#x1f923;&#x1f923; 在 Scala 中&#xff0c;数组是一种特殊的集合类型&#xff0c;可以是可变的也可以是不可变的。 1. 不可变数组 在 Scala 中&#xff0c;不可变…

Kylin Server V10 下 Nacos 集群部署

集群部署架构图 端口 与主端口的偏移量 描述 8848 0 主端口,客户端、控制台及

摄像头原始数据读取——V4L2(userptr模式,V4L2_MEMORY_USERPTR)

摄像头原始数据读取——V4L2(userptr模式,V4L2_MEMORY_USERPTR) 用户指针方式允许用户空间的应用程序分配内存&#xff0c;并将内存地址传递给内核中的驱动程序。驱动程序直接将数据填充到用户空间的内存中&#xff0c;从而避免了数据的拷贝过程。 流程&#xff1a; 通过VIDI…

亚马逊开发视频人工智能模型,The Information 报道

根据《The Information》周三的报道&#xff0c;电子商务巨头亚马逊&#xff08;AMZN&#xff09;已开发出一种新的生成式人工智能&#xff08;AI&#xff09;&#xff0c;不仅能处理文本&#xff0c;还能处理图片和视频&#xff0c;从而减少对人工智能初创公司Anthropic的依赖…

一次完整的CNAS软件测试实验室内部审核流程

内部审核是软件测试实验室管理体系重的重要部分&#xff0c;通过内部审核可以为有效的管理评审和纠正、预防措施提供信息&#xff0c;以验证组织的管理体系是否持续的满足规定的要求并且正在运行。 内部审核需要依据文件化的程序&#xff0c;每年至少实施一次&#xff0c;软件…

Matlab数字信号处理——音频信号处理与分析GUI

1.实现内容 实现功能有回响、变声、倒放、变速、音量调整、加噪、设计 FIR和 IR 滤波器实现去噪功能(高通低通带通带阻)&#xff0c;并且在时域波形图和频域波形展示变化。滤波器包括各种参数的选择、滤波器结构和类型的选择等。同时GUI上还包含打开、播放、保存、退出功能。 …

pcb线宽与电流

三十年一路高歌猛进的中国经济&#xff0c; 中国经历了几个三十年&#xff1f; 第一个三十年&#xff1a;以计划为导向。 第二个三十年&#xff1a;以经济为导向。 现在&#xff0c;第三个三十年呢&#xff1f; 应该是以可持续发展为导向。 传统企业摇摇欲坠&#xff0c; 新兴企…

redis命令 及 redis 常见的数据结构

文章目录 一. 核心命令1. set2. get 二. 全局命令1. keys2. exists3. del4. expire5. ttl6. type 三. redis 常见的数据结构 一. 核心命令 1. set set key value key 和 value 都是string类型的 对于key value, 不需要加上引号, 就是表示字符串类型, 加上也可以 redis中, 不…

跨平台应用开发框架(4)----Qt(系统篇)

目录 1.Qt事件 1.事件来源 2.事件处理 3.按键事件 1.组合按键 4.鼠标事件 1.鼠标单击事件 2.鼠标释放事件 3.鼠标双击事件 4.鼠标移动事件 5.滚轮事件 5.定时器 1.QTimerEvent类 2.QTimer 类 3.获取系统日期及时间 6.事件分发器 7.事件过滤器 2.Qt文件 1.输入…

uniapp在App端定义全局弹窗,当打开关闭弹窗会触发onShow、onHide生命周期怎么解决?

在uniapp(App端)中实现自定义弹框&#xff0c;可以通过创建一个透明页面来实现。点击进入当前页面时&#xff0c;页面背景会变透明&#xff0c;用户可以根据自己的需求进行自定义&#xff0c;最终效果类似于弹框。 遇到问题&#xff1a;当打开弹窗(进入弹窗页面)就会触发当前页…

DM达梦管理工具拖出空白区块,无法关闭

1. 出现问题&#xff1a;DM达梦管理工具拖出空白区块&#xff0c;无法关闭。 2. 解决方法 新建查询页&#xff0c;把查询页拖到空白区块里&#xff0c;完全覆盖空白区块。之后空白区块会变成查询页&#xff0c;右上角会出现叉号&#xff0c;点击叉号关闭就行。 3. 后记 达梦…

DevExpress的web Dashboard应用

本文旨在从零开始创建一个包含dashboard的应用 一、前期准备 1、语言&#xff1a;C# 2、软件&#xff1a;Visual Studio 2019 3、框架&#xff1a;DevExpress19.2(付费)、ASP.NET(Web) 4、组件&#xff1a;dashboard 二、创建ASP.NET Web窗体仪表板应用程序 1、创建一个空的w…

【vue-router】Vue-router如何实现路由懒加载

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…