JDBC相关记录

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而言的,如果有其他模块也需要,那么对那个模块进行同样的设置)

引入成功后,可以在这个地方查看:

相关推荐
云烟成雨TD4 小时前
Spring AI Alibaba 1.x 系列【69】Token 用量统计
java·人工智能·spring
JAVA9654 小时前
JAVA面试-并发篇 03-使用synchronized doublecheck实现单例有什么坑
java·单例模式·面试
在繁华处4 小时前
Java从零到熟练(四):面向对象基础
java·开发语言
小江的记录本6 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
在繁华处6 小时前
Java从零到熟练(三):流程控制
java·开发语言·python
唐青枫6 小时前
Java Optional 实战指南:优雅处理空值与链式转换
java
一起学开源6 小时前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
逍遥德7 小时前
MQTT教程详解-04.SpringBoot集成MQTT(告别手动控制)
java·spring boot·物联网·中间件·iot·iotdb
语戚7 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
我命由我123458 小时前
Android 开发问题:MlKitException: An internal error occurred during initialization.
android·java·java-ee·android jetpack·android-studio·androidx·android runtime