JDBC相关记录

news2024/9/21 4:31:58

JDBC:Java DadaBase Connectivity 即Java语言连接数据库。
本质:JDBC是SUN公司制定的一套接口(interface)。
作用:不同的数据库有自己独特设计原理,JDBC的可以让Java程序员关注业务本身,而不需要关注数据库底层是怎么实现的。

在这里插入图片描述(面向接口编程的作用:解耦合——降低程序的耦合度,提高程序的扩展力。多态机制就是典型的面向抽象编程。)
JDBC开发前的准备工作:先从官网下载对应的驱动jar包,然后将其配置到环境变量classpath当中(针对文本编辑器开发,使用IDEA有自己的配置方式)。

JDBC编程六步

  1. 注册驱动——告诉Java程序,即将要连接的是哪个品牌的数据库;
  2. 获取连接——表示JVM的进程和数据库进程之间的通道打开了,这属于进程之间的通信,使用之后一定要关闭;
  3. 获取数据库操作对象(专门执行sql语句的对象);
  4. 执行SQL语句(DQL, DML);
  5. 处理查询结果集——只有当第四步执行的是select语句的时候,才有这第五步处理查询结果;
  6. 释放资源——使用完资源之后一定要关闭资源,Java和数据库属于进程之间的通信,开启后一定要关闭。

注册驱动与获取连接
注意区别驱动定义的类及其实现的接口,通过包名——com.mysql.jabc来区分。
在这里插入图片描述
举例:
在这里插入图片描述
常用注册方式(利用反射机制):
在这里插入图片描述因为com.sql.jdbc.Driver中实现了注册的静态方法:
在这里插入图片描述
使用资源拜访定期绑定属性配置文件
先创建配置文件:
在这里插入图片描述
在这里插入图片描述
注意:实际开发中不建议把连接数据库的信息写死在java程序中。

处理查询结果集
使用executeQuery执行查询语句;通过.next()方法判断是否有数据;使用.getString()方法获取数据,其中的参数表示第几列。
在这里插入图片描述提高程序的健壮性——通过列名(查询结果的列名,不是表中的列名)访问数据:
在这里插入图片描述
用特定类型的获取数据值:
在这里插入图片描述

IDEA配置驱动

右击module(创建的模块)——> Open Module Settings :
在这里插入图片描述
点击Libraries ——> 点击+号,选择java ——> 添加驱动的jar包:
在这里插入图片描述(当前添加的驱动jar包是针对这个module而言的,如果有其他模块也需要,那么对那个模块进行同样的设置)
引入成功后,可以在这个地方查看:
在这里插入图片描述

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

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

相关文章

Programming abstractions in C阅读笔记:p181-p183

《Programming Abstractions In C》学习第61天,p181-p183总结。 一、技术总结 1.linear search algorithm 2.lexicographic order(字典顺序) 3.binary search algorithm(二分查找算法) /** 1.二分查找也应用了递归的思想。* 2.这里的代码只是demo*/ #include &…

17.2 实现无管道正向CMD

WSASocket 无管道正向CMD,使用WSASocket函数创建一个TCP套接字,并绑定到一个本地地址和端口上。然后使用CreateProcess函数创建一个新的CMD进程,并将标准输入、输出和错误输出重定向到套接字的句柄上。这样,客户端可以通过网络连接…

应用开发平台集成工作流系列之16——办理意见设计与实现

背景 流程任务流转过程中,各环节的处理,会填写处理意见。 Camunda自带了相关的功能,但功能过于简陋,问题较多,今天来说说这一块。 自带功能的问题 如使用Camunda官方自身的办理意见相关功能,会遇到两个问…

【C++进阶(九)】C++多态深度剖析

💓博主CSDN主页:杭电码农-NEO💓   ⏩专栏分类:C从入门到精通⏪   🚚代码仓库:NEO的学习日记🚚   🌹关注我🫵带你学习C   🔝🔝 多态 1. 前言2. 多态的概念以及定义3. 多态的实…

Generator异步解决方案详解

一:三种常见的异步解决方案 Promise:链式编程async:使用 async 去修饰函数,然后使用 await 去等待成功Generator:使用 * 修饰函数,然后使用 yield 去等待成功 通俗来讲,Generator 类似于 Promi…

【Java 进阶篇】Java XML组成部分:理解XML的结构

XML(可扩展标记语言)是一种常用于存储和交换数据的标记语言。了解XML的结构和组成部分对于有效处理XML数据至关重要。在本篇博客中,我们将深入探讨XML的组成部分,以及如何使用Java来处理和操作XML数据。 什么是XML? …

预测宝可梦武力值、分类宝可梦

regression case 股票预测 无人车看到的各种sensor 影像镜头看到马路上的东西作为输入,输出就是方向盘角度等等的操纵策略 scalar 标量 这个是热力图,相当于你的XYZ但是Z用颜色表示了 closed-form solution 闭合解 learning rate事先定好的数值 在lin…

Vue中的v-for指令是用来做什么的?

在Vue中,v-for是一个用于渲染列表或集合的指令。它通过迭代数据源中的每个元素,生成对应的DOM节点或组件实例,并将它们渲染到页面上。 v-for指令的基本语法如下: <template><div><ul><li v-for="item in items" :key="item.id"…

基于ssm流浪动物领养救助系统

摘要 基于SSM&#xff08;Spring SpringMVC MyBatis&#xff09;的流浪动物领养救助系统是一个用于管理和帮助流浪动物领养、救助的信息化平台。该系统旨在提供一种便捷、高效的方式&#xff0c;以协调和改善流浪动物的生活&#xff0c;并促进社会各界的参与和支持。以下是该…

重生奇迹mu“荣誉之城”勇者大陆

曾经&#xff0c;不少重生奇迹mu玩家讨论最经典的新人出生地&#xff0c;有的说是仙踪林&#xff0c;有的则是说勇者大陆&#xff0c;最后在重生奇迹mu网站上面&#xff0c;以投票的方式最终得出一个答案&#xff0c;那就是勇者大陆&#xff0c;游戏里面当之无愧的荣誉之城&…

c语言程序设计——题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

题目&#xff1a;将一个正整数分解质因数。例如&#xff1a;输入90,打印出902*3*3*5。 程序分析&#xff1a;对n进行分解质因数&#xff0c;应先找到一个最小的质数k&#xff0c;然后按下述步骤完成 (1)如果这个质数恰等于&#xff08;小于的时候&#xff0c;继续执行循环&…

C#,数值计算——分类与推理Phylo_nj的计算方法与源程序

1 文本格式 using System; using System.Collections.Generic; namespace Legalsoft.Truffer { public class Phylo_nj : Phylagglom { public double[] u; public override void premin(double[,] d, int[] nextp) { i…

spring6-国际化:i18n | 数据校验:Validation

文章目录 1、国际化&#xff1a;i18n1.1、i18n概述1.2、Java国际化1.3、Spring6国际化1.3.1、MessageSource接口1.3.2、使用Spring6国际化 2、数据校验&#xff1a;Validation2.1、Spring Validation概述2.2、实验一&#xff1a;通过Validator接口实现2.3、实验二&#xff1a;B…

AI只需26秒,就可以设计一款会走路的机器人

由西北大学、麻省理工学院和佛蒙特大学组成的一支科研团队首次开发出一种可以完全自行设计机器人的 AI 算法。 这一 AI 算法不仅运行速度快&#xff0c;还可在个人计算机上运行&#xff0c;并从头开始设计全新的结构。只需告诉AI“我们想要一个可穿越陆地的机器人”&#xff0c…

【Java 进阶篇】Java XML快速入门:理解、解析和生成XML

XML&#xff08;可扩展标记语言&#xff09;是一种常用于存储和交换数据的标记语言&#xff0c;而Java是一种强大的编程语言&#xff0c;它具有处理XML的能力。在本篇博客中&#xff0c;我们将探讨XML的基础知识&#xff0c;学习如何在Java中解析和生成XML文档&#xff0c;以及…

一次OOM故障分析

一、前言 昨天门店POS系统发生了一次因为OOM引起的Down机事件&#xff0c;本文我们就来讲一下故障排查和解决问题过程。 二、故障发生 吃完中饭正在休息&#xff0c;业务方说POS的后台管理系统进行库存盘点出错&#xff0c;截图过来的报错信息里有&#xff1a;连接POS前台系…

《向量数据库》——向量数据库Milvus Cloud 和Dify比较

Zilliz Cloud v.s. Dify Dify 作为开源的 LLMs App 技术栈&#xff0c;在此前已支持丰富多元的大型语言模型的接入&#xff0c;除了 OpenAI、Anthropic、Azure OpenAI、Hugging face、Replicate 等全球顶尖模型及模型托管平台&#xff0c;也完成了国内主流的各大模型支持&#…

1024 CSDN 程序员节-知存科技-基于存内计算芯片开发板验证语音识别

前言 在今年的 CSDN 程序员节上&#xff0c;我参与了这次知存科技举办的一个 AI Workshop 小活动——“基于存内计算芯片开发板验证语音识别”&#xff0c;并且有幸成为完成任务的学习者之一XD。上一次参与类似的活动是算能公司举办的“千校万里行”AIGC 大模型编译部署活动&a…

logging日志改造---自定义参数传递到格式中

目录 一&#xff1a;需求二&#xff1a;实现方式三&#xff1a;存在的问题3.1: 问题描述3.2: 源码分析3.3: 解决方案 四&#xff1a;相关链接 一&#xff1a;需求 需求&#xff1a;将自定义的参数&#xff0c;放在日志的指定格式中。 二&#xff1a;实现方式 例如&#xff1…

三维模型表面积计算方法

【版权声明】 本文为博主原创文章&#xff0c;未经博主允许严禁转载&#xff0c;我们会定期进行侵权检索。 更多算法总结请关注我的博客&#xff1a;https://blog.csdn.net/suiyingy&#xff0c;或”乐乐感知学堂“公众号。 本文章来自于专栏《Python三维模型处理基础》的系列文…