JDBC以及事务

1、JDBC是什么?

        JDBC是Java DataBase Connectivity(Java语言链接数据库)

2、JDBC的本质

        JDBC是一套接口,有调用者(java工程师)和实现者(SUN公司)(实现类被称为驱动)之分,跟面向接口调用、面向接口写实现类,都属于面向接口编程

  • 为什么面向接口?
    • 解耦合:降低程序的耦合度,提高程序的扩展力;

3、关系

4、JDBC编程6步

- 第一步:注册驱动(作用:告诉Java程序,即将要链接的是哪个品牌的数据库)(DriverManager接口)- 第二步:获取连接(表示JVM的进程与数据库的进程打开了,这属于进程之间的通信,使用完后一定要关闭)(Connection接口)- 第三步:获取数据库操作对象 (专门执行sql语句的对象)(Statement接口、PreparedStatement接口)- 第四步:执行SQL语句(主要是DML DQL)- DML(数据操作语言): insert、delete、update,对表中的数据进行增删改- 第五步:处理查询 结果集(只有第四部执行的是select语句时,这一步才会执行)(ResultSet接口)- 第六步: 释放资源(使用完之后一定要关闭资源,Java和数据库属于进程间的通信,开启之后一定要关闭)(close)

 5、JDBC事务

  •  什么是事务
    • 事务是数据库提供的一个特性
    • 事务:组成各个数据的(最小)执行单元,要么都成功,要么都失败
    • 我们使用一个例子来说明:以转账为例
      • * 转账的功能,冠希给美美转1000元钱。    
        * 使用事务    
        * 	先给冠希扣除掉1000元        
        * 	再给美美加上1000元        
        * 事务结束了
      •  在MYSQL中操作
        • create table t_account(    
          id int primary key auto_increment,        
          username varchar(20),        
          money double        
          );--两种方式,第一种:使用命令的方式
          start transaction;		--开启事务
          update t_account set money = money ‐ 1000 where username = '冠希';
          update t_account set money = money + 1000 where username = '美美';
          commit;					--提供事务(事务已经结束了,数据永久的保存到数据库中了)
          rollback;				--回滚事务(事务已经结束了,数据回滚到最初始化的状态)--第二种方式:设置MySQL事务不默认提交的方式
          --MySQL数据库的事务是默认提交的。
          update t_account set money = money ‐ 1000 where username = '冠希';   --默认使用了一个事务
          --设置让MySQL的数据库的事务不默认提交
          set autocommit = off或者0
          --编写SQL语句(执行完,都没有提交)
          sql1
          sql2
          --手动提交和回滚
          commit;
          rollback;
  •  事务的特性
    • 原子性
      • 表示事务中所有操作是不可再分割的原子单位
    • 一致性
      • 事务执行前后数据需要保证一致
    • 隔离性
      • 多个事务同时操作一条记录,事务之间不能互相干扰
    • 持久性
      • 事务一旦结束了,数据将永久的保存到数据库中
  • 事务的隔离
    • 不考虑隔离性所引发的问题
      • 1、脏读:一个事务读取到了另一个事务未提交的数据
        2、不可重复读:一个事务读取到了另一个事务提交的数据,导致了多次查询的结果不一致。强调的是update,修改记录的数据。
        3、虚度(幻读):一个事务读取到了另一个事务提交的数据,导致了多次查询的结果不一致。强调是insert,向表中添加一条数据。
    •  设置隔离级别
      • 事务的隔离级别
        • Read uncommitted		--读未提交,什么都解决不了
          Read committed			--读已提交,避免脏读,但是不可重复读和虚读有可能产生
          Repeatable read			--可重复度,避免脏读和不可重复读,虚度有可能产生的(mysql默认)
          Serializable			--串行,避免各种读(当有一个事务的级别达到此时就会上锁,另一个就不再允许                                                                                    执行任何修改操作,以此达到避免各种问题的目的)

           

      •   4中隔离的安全性和效率
        • 安全		Serializable > Repeatable read > Read committed > Read uncommitted
          效率		Serializable < Repeatable read < Read committed < Read uncommitted

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

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

相关文章

Android13系统导航栏添加音量加减键按钮功能

不知道为什么拿到芯片原厂发布给我们的Android13系统源码编译后&#xff0c;导航栏没有音量加减键&#xff0c;客户有反馈这个问题&#xff0c;所以特意加了一下&#xff0c;修改记录如下&#xff1a;frameworks/base目录下 commit 9cb2244d61a237cab03c540bfcca6e4fac2bea2c …

Linux OpenGrok搭建

文章目录 一、目的二、环境三、相关概念3.1 OpenGrok3.2 CTags3.3 Tomcat 四、OpenGrok搭建4.1 安装jdk4.2 安装ctags依赖4.3 安装universal-ctags4.3.1 下载universal-ctags4.3.2 编译&&安装universal-ctags 4.4 安装Tomcat4.4.1 下载&&解压Tomcat4.4.2 启动T…

继续捡钱,每天几百块!

每日操作计划&#xff1a; 标普信息科技(161128)&#xff0c;溢价8.5%&#xff0c;限购100&#xff0c;一拖七&#xff0c;单户每天700*8.5%59元 印度基金LOF(164824)&#xff0c;溢价2.6%&#xff0c;限购100&#xff0c;一拖七&#xff0c;单户每天700*2.6%18元 美元债LOF(…

【leetcode系列】46.全排列

题目&#xff1a;给定一个不含重复数字的数组 nums &#xff0c;返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,3] 输出&#xff1a;[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]] 示例 2&#xff1a; 输入&am…

算法力扣刷题记录 二十【18题. 四数之和】

前言 哈希篇&#xff0c;继续。 记录 二十【18题. 四数之和】 一、题目阅读 给你一个由 n 个整数组成的数组 nums &#xff0c;和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] &#xff08;若两个四元组元素一…

为什么要本地化您的多媒体内容?

当我们访问网站、应用程序和社交媒体时&#xff0c;体验不再局限于陈旧的文本和静态图像。现代处理能力和连接速度提高了快速加载视频、音频和动画的可能性。 这一切都提供了更具沉浸感和互动性的用户体验。多媒体是数字营销中最有效的内容之一&#xff0c;因为它对用户更具吸…

vue-cli 项目打包优化-基础篇

1、项目打包完运行空白 引用资源路径问题&#xff0c;打包完的【index.html】文件引用其他文件的引用地址不对 参考配置&#xff1a;https://cli.vuejs.org/zh/config 修改vue.config.js &#xff0c;根据与 后端 或 运维 沟通修改 module.export {// 默认 publicPath: //…

使用API有效率地管理Dynadot域名,为文件夹中的域名设置域名转发

关于Dynadot Dynadot是通过ICANN认证的域名注册商&#xff0c;自2002年成立以来&#xff0c;服务于全球108个国家和地区的客户&#xff0c;为数以万计的客户提供简洁&#xff0c;优惠&#xff0c;安全的域名注册以及管理服务。 Dynadot平台操作教程索引&#xff08;包括域名邮…

全彩屏负氧离子监测站

TH-FZ5在追求绿色生态、健康出行的今天&#xff0c;景区不仅仅是人们休闲游玩的好去处&#xff0c;更是人们体验大自然、感受清新空气的重要场所。为了进一步提升游客的游览体验&#xff0c;许多景区纷纷引入了全彩屏负氧离子监测站&#xff0c;这一创新举措不仅为景区增添了科…

【怀庄之醉白酒】怀庄之醉酱香白酒哪款好?

【怀庄之醉酱香白酒】在怀庄之醉酱香白酒的丰富系列中&#xff0c;怀庄之醉尊品、怀庄之醉三星和怀庄之醉匠心之作是三款受到广泛欢迎的产品。 每一款酒都具备其独特的风味和适合的饮用场合。以下是对这三款酒特性的分析&#xff1a; 怀庄之醉 尊品&#xff1a;怀庄之醉 尊品…

云通SIPX,您的码号资源智能调度专家!

在数字化转型的浪潮中&#xff0c;号码资源作为企业与客户沟通的重要桥梁&#xff0c;其管理效率直接关系到企业运营的成败。随着运营商对号码资源管理的规范化和精细化&#xff0c;企业对高效、智能的号码资源管理需求日益增长&#xff0c;以实现对外呼叫的降本增效。 一、什么…

学生成绩管理系统带8000字文档学生选课管理系统java项目javaweb项目ssm项目jsp项目java课程设计java毕业设计

文章目录 学生选课成绩管理系统一、项目演示二、项目介绍三、8500字项目文档四、部分功能截图五、部分代码展示六、底部获取项目源码带8500字文档&#xff08;9.9&#xffe5;带走&#xff09; 学生选课成绩管理系统 一、项目演示 选课成绩管理系统 二、项目介绍 语言: Java …

php数据结构之链表

本文由 ChatMoney团队出品 链表的基本概念 链表&#xff08;Linked List&#xff09;是一种常见的数据结构&#xff0c;它由一系列节点组成&#xff0c;每个节点除了存储数据外&#xff0c;还包含指向下一个节点的指针。与数组相比&#xff0c;链表在插入和删除操作上具有更高…

直播带货大模型,开启自动卖货的时代

Streamer-Sales是一个为直播带货主播量身定制的智能工具。 它能够智能分析商品特性&#xff0c;自动创作出引人入胜的解说词&#xff0c;从而有效增强商品的吸引力和提升销售业绩。它还具备多种交互功能&#xff0c;比如将主播的语音实时转换为文字&#xff0c;便于与观众进行…

移动端 UI 风格,书写华丽篇章

移动端 UI 风格&#xff0c;书写华丽篇章

原创作品—医疗行业软件界面UI、交互设计

在医疗行业大屏UI设计中&#xff0c;首要的是以用户为中心&#xff0c;深入理解医生、护士、管理层等用户群体的具体需求和工作流程。大屏设计应直观展示关键医疗数据、患者信息、设备状态等&#xff0c;确保用户能够迅速、准确地获取所需信息。同时&#xff0c;功能布局应合理…

12寸和8寸封装线的差异点

12英寸&#xff08;300mm&#xff09;晶圆封装线与8英寸&#xff08;200mm&#xff09;晶圆封装线在多个方面存在显著区别&#xff0c;这些区别影响了它们的生产效率、成本结构和适用技术。以下是一些主要差异&#xff1a; 1. **晶圆面积**&#xff1a; - 12英寸晶圆拥有更…

​​植物大战僵尸杂交版直装版v2.1 安卓版:全新策略塔防体验

《植物大战僵尸杂交版直装版》v2.1是由B站UP主“潜艇伟伟迷”精心制作的同人游戏&#xff0c;为策略塔防手游带来了全新的活力。游戏中引入了众多创新的杂交植物&#xff0c;例如结合了向日葵的阳光生成能力和豌豆射手的攻击特性的向日葵豌豆射手&#xff0c;以及拥有寒冰豌豆射…

docker打包 arm32v7/debian 问题总结

1.架构不同 我的宿主是x86 ,但是打包的是arm架构 安装qemu sudo apt-get install binfmt-support qemu qemu-user-static 然后使用buildx打包 docker buildx build --no-cache --platform linux/arm/v7 -t tdc_post:1.0.1 . --load 保存tar docker save -o tdc_post.tar tdc_p…

金融科技如何运用技术手段实现细颗粒度服务

随着金融科技的快速发展&#xff0c;金融机构正在通过采用各种技术手段来提供更加细颗粒度的服务&#xff0c;以满足客户日益增长的个性化需求。这些技术手段不仅提高了金融服务的效率和安全性&#xff0c;还显著提升了用户体验和满意度。 一、大数据分析与人工智能&#xff08…