JDBC-Java与数据库

JDBC

快速入门

  1. 导入jar包
    • 以 mysql 为例
  2. 注册驱动

Class.forName(“mysql.jdbc.Driver”)

  1. 获取连接

Connection conn = DriverManager.getConnection(url, username, password);

  1. 定义Sql语句

String sql = “update …”

  1. 获取执行Sql对象

Statement stmt = conn.createStatement();

  1. 执行SQL

stmt.executeUpdata(sql);

  1. 处理返回结果
  2. 释放资源
public class JDBCDemo {public static void main(String[] args) throws Exception {// 1. 注册驱动Class.forName("com.mysql.jdbc.Driver");// 2. 获取连接String url = "jdbc:mysql://127.0.0.1:3306/db1" ;String username = "admin";String password = "123456";Connection conn = DriverManager.getConnection(url, username, password);// 3. 定义sql语句String sql = "update account set money = 2000 where id = 1 ";// 4. 获取执行sql的对象Statement stmt = conn.createStatement();// 5. 执行sqlint count = stmt.executeUpdate(sql);// 6. 处理结果System.out.println(count);// 7. 释放资源stmt.close();conn.close();}
}

JDBC API 详解

Driver Manager

  1. 注册驱动: DriverManager.registerDiver();
  2. 获取连接:DriverManager.getConnection(url, username, password)
    • url 连接路径
    • 语法:jdbc:mysql://ip地址(域名):端口号/数据库名称?参数键值对1&参数键值对2…
    • 示例:jdbc:mysql://127.0.0.1:3306/db1
    • 示例:将安全连接禁用即可消除警告 jdbc:mysql://127.0.0.1:3306/db1?uesSSL=false

Connection

  1. 获取执行sql对象

  2. 管理事务

    • mysql 事务管理

      1. 开启事务:BEGIN; /START TRANSACTION;
      2. 提交事务:COMMIT
      3. 回滚事务:ROLLBACK
      4. Mysql 默认自动提交事务
    • JDBC 事务管理:Connection接口中定义了3个对应的方法

      1. 开启事务:setAutoCommit(bool autoCommit) :true为自动提交事务,false为手动提交事务,即为开启事务
      2. 提交事务:commit()
      3. 回滚事务:rollback()

注意 : Java 中 通过 try - catch 机制来实现 事务的回滚

Statement

  1. 执行 sql 语句 :

    • int excuteUpdate(sql) :执行 DML 和 DDL 语句
      返回值:(1)DML语句影响的行数;(2)DDL语句执行后,执行成功也可能会返回0
    • ResultSet executeQuery(sql) :执行DQL语句
      返回值:Result结果集对象

    补充

    1. DDL :对表和库的增删改操做
    2. DML:对数据的增删改操作
    3. DQL:对数据的查询操作

ResultSet

  1. 封装了DQL查询语句的结果

    • 获取查询结果

    boolean next() :(1) 将光标从当前位置向前移动一行 (2)判断当前行是否为有效行

    返回值 : true : 有效行,当前行有数据; false :无效行,当前行没有数据;

  2. xxx getXxx(参数):获取数据

    • xxx 数据类型;如 int getInt(参数) String getString(参数)
    • 参数:
      • int 列的编号
      • String 列的名称

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

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

相关文章

leetcode34:在排序数组中查找元素的第一个和最后一个位置

题目链接&#xff1a;34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣&#xff08;LeetCode&#xff09; class Solution { public:vector<int> searchRange(vector<int>& nums, int target) {if(nums.empty()) {return {-1, -1};}vector<int> R…

git\repo

常用git和repo命令_repo git-CSDN博客文章浏览阅读1.5w次&#xff0c;点赞9次&#xff0c;收藏112次。常用git和repo命令文章收集了最近使用的一些repo和git命令&#xff0c;下图是个人理解的git文件状态转换图。 相关概念 名称 意义 repo 谷歌用Python脚本写的调用git的一个脚…

【Linux】进程_5

文章目录 五、进程6. 进程的调度和转换7. 环境变量 未完待续 五、进程 6. 进程的调度和转换 进程在运行过程中&#xff0c;要产生大量的临时数据&#xff0c;存放在CPU的寄存器中&#xff0c;CPU内部的所有临时数据我们叫做进程的 硬件上下文。当进程的时间片到了时&#xff…

基于Python-CNN深度学习的物品识别

基于Python-CNN深度学习的物品识别 近年来&#xff0c;深度学习尤其是卷积神经网络&#xff08;CNN&#xff09;的快速发展&#xff0c;极大地推动了计算机视觉技术的进步。在物品识别领域&#xff0c;CNN凭借其强大的特征提取和学习能力&#xff0c;成为了主流的技术手段之一…

【Android面试八股文】谈一谈你对http和https的关系理解

文章目录 HTTPHTTPSSSL/TLS协议HTTPS加密、解密流程HTTP 和 HTTPS 的关系具体的差异实际应用总结扩展阅读HTTP(HyperText Transfer Protocol)和HTTPS(HyperText Transfer Protocol Secure)是用于在网络上进行通信的两种协议。 它们在很多方面是相似的,但关键的区别在于安全…

【机器学习】对大规模的文本数据进行多标签的分类处理

1. 引言 1.1. NLP研究的背景 随着人工智能技术的飞速发展&#xff0c;智能助手、聊天机器人和虚拟客服的需求正呈现出爆炸性增长。这些技术不仅为人们提供了极大的生活便利&#xff0c;如日程管理、信息查询和情感陪伴&#xff0c;还在工作场景中显著提高了效率。聊天机器人凭…

【proteus仿真】基于51单片机的秒表设计

【proteus仿真】基于51单片机的秒表设计 资料获取在文章结尾处&#xff01; 更多资料获取链接&#xff1a; https://docs.qq.com/sheet/DTExIc2dPUUJ5enZZ?tabBB08J2 1.资料内容 源码proteus仿真图 演示视频&#xff1a; 【proteus仿真】基于51单片机的秒表设计_哔哩哔…

AI日报|英伟达Nemotron-4 340B模型助力各行业数据生成,扣子发起匿名AI模型擂台赛!

文章推荐 AI日报&#xff5c;跃问App上架加入AI助理竞争&#xff01;GPTZero获千万美元A轮融资&#xff0c;创始人不到30岁&#xff01; AI日报&#xff5c;Luma推出AI视频模型&#xff0c;又一Sora级选手登场&#xff1f;SD3 Medium发布&#xff0c;图中文效果改善明显 ⭐️…

Day41

Day41 文件的上传 浏览器底层是通过输入流读取文件&#xff0c;通过输出流传输到服务器&#xff0c;服务器通过输入流读取数据&#xff0c;通过输出流将文件保存在本地。注意&#xff1a;浏览器的表单不许用post请求&#xff0c;get请求会将数据显示在地址栏里。 上传头像 场景…

FFmpeg AAC文件和H264文件合成MP4/FLV文件

使用FFmpeg库把AAC文件和H264文件合成MP4/FLV文件&#xff0c;FFmpeg版本为4.4.2-0。 需要aac和h264测试文件的&#xff0c;可以从我上传的MP4文件中用ffmpeg提取&#xff0c;命令如下&#xff1a; ffmpeg -i <input.mp4> -map 0:v -c:v copy <output.h264> -map…

【数据结构与算法(C语言)】循环队列图解

目录 1. 前言1.1 普通循环队列假溢出1.1.1 初始化队列1.1.2 插满队列1.1.3 删除元素后&#xff0c;再插入元素 1.2 循环队列1.2.1 插入元素&#xff0c;队列已满1.2.2 将元素J1、J2出列&#xff0c;循环队列又空出两个空间1.2.3 元素J6可以继续入列 2. 存储结构和函数说明2.1 队…

vivado PIP or SITE_PIP、PKGPIN_BYTEGROUP

PIP是Xilinx部件上用于路由连接或网络的设备对象。PIP 称为ARC的连接多路复用器可以编程为将一根电线连接到 另一个&#xff0c;从而将节点连接在一起&#xff0c;以形成中特定NET所需的路由 设计。 SITE_PIP&#xff0c;也称为路由BEL&#xff0c;是SITE内部的连接多路复用器&…

嵌入式跨平台编译:vsftpd

下载 https://security.appspot.com/vsftpd.html 或者直接下载&#xff1a; https://download.csdn.net/download/quantum7/89451093 解压 tar xf vsftpd-3.0.5.tar.gz 编译 export CROSS_NAMEaarch64-mix210-linux export PATH$PATH:/opt/linux/x86-arm/${CROSS_NAME}/…

力扣爆刷第153天之TOP100五连刷(相交、翻转、排序链表、螺旋矩阵、锯齿二叉树)

力扣爆刷第153天之TOP100五连刷&#xff08;相交、翻转、排序链表、螺旋矩阵、锯齿二叉树&#xff09; 文章目录 力扣爆刷第153天之TOP100五连刷&#xff08;相交、翻转、排序链表、螺旋矩阵、锯齿二叉树&#xff09;一、103. 二叉树的锯齿形层序遍历二、92. 反转链表 II三、54…

Python for循环中的引用传递和值传递

先上代码&#xff1a; a [[1],[2],[3]] b [[4,5],[6,7],[7,8]] for i,j in zip(a,b):print(i,j)i [9]#i[0] 8j[:2][1,2]print(i, j) print(a) print(b) 运行的结果&#xff1a; [1] [4, 5] [9] [1, 2] [2] [6, 7] [9] [1, 2] [3] [7, 8] [9] [1, 2] [[1], [2], [3]] [[1…

android常用知识

透明activity样式&#xff1a; android:theme"android:style/Theme.Translucent.NoTitleBar.Fullscreen"这句代码&#xff0c;当你是建的empty activity project时&#xff0c;默认继承的是AppCompat这个类。所以在AndroidMifext.xml文件中用上述代码会导致程序错误&…

ROM 和 RAM

ROM (只读存储器) 和 RAM (随机存取存储器) 是计算机系统中两种不同类型的存储器。它们在定义、用途、工作原理、数据可写性和典型应用方面存在显著差异。 ROM &#xff08;Read-Only Memory&#xff09;(只读存储器) 定义:ROM 是一种只读存储器,用于存储计算机的固件和永久性…

Qt | 简单的使用 QStyle 类(风格也称为样式)

01、前言 者在 pro 文件中已添加了正确的 QT+=widgets 语句 02、基础样式 1、QStyle 类继承自 QObject,该类是一个抽像类。 2、QStyle 类描述了 GUI 的界面外观,Qt 的内置部件使用该类执行几乎所有的绘制,以确保 使这些部件看起来与本地部件完全相同。 3、Qt 内置了一系…

linux段异常信号量

在 Linux 系统中&#xff0c;段异常&#xff08;Segmentation Fault&#xff09;和信号量&#xff08;Semaphore&#xff09;是两个不同的概念&#xff0c;但它们都与进程间通信&#xff08;IPC&#xff09;和错误处理有关。我会分别解释它们&#xff0c;然后解释它们之间可能的…