iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在Java中利用JDBC实现一个事务功能
  • 326
分享到

怎么在Java中利用JDBC实现一个事务功能

2023-05-30 17:05:15 326人浏览 薄情痞子
摘要

本文章向大家介绍怎么在Java中利用JDBC实现一个事务功能,主要包括怎么在Java中利用JDBC实现一个事务功能的使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。Java是什么Java是一门面

本文章向大家介绍怎么在Java中利用JDBC实现一个事务功能,主要包括怎么在Java中利用JDBC实现一个事务功能的使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

Java是什么

Java是一门面向对象编程语言,可以编写桌面应用程序、WEB应用程序、分布式系统和嵌入式系统应用程序。

1. 转账业务

转账必须执行2个sql语句(update更新)都成功的情况下,提交事务,如果有一个失败,则2个都回滚事务

2. 事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。

① 原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。
② 一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
③ 隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
④ 持久性(durability)。持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

3. 这里以转账操作为案例进行演示说明,其注意点如下:

(1)一个sql语句操作不需要手动提交事务

(2)查询操作也不需要手动提交事务,

(3)但是更新,插入,删除都需要手动提交事务

(4)余额为负的可以先查询出结果再进行判断,然后再操作

(5)con.setAutoCommit(false);手动开启事务;con.commit();手动提交事务;con.rollback();事务回滚操作

4. 首先创建一个数据表或者两个数据表,这里为了演示清楚创建两个数据表

怎么在Java中利用JDBC实现一个事务功能

怎么在Java中利用JDBC实现一个事务功能

5. 创建好数据库和数据表,然后进行工具类的书写BaseDao.java

package com.bie.utils;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;public class BaseDao {  private static String driver="com.mysql.jdbc.Driver";  private static String url="jdbc:Mysql:///test";  private static String user="root";  private static String passWord="123456";    public static Connection getCon() throws ClassNotFoundException, SQLException{    Class.forName(driver);//加载数据库驱动    System.out.println("测试加载数据库成功");    Connection con=DriverManager.getConnection(url, user, password);    System.out.println("测试数据库链接成功");    return con;  }    public static void close(Connection con,PreparedStatement ps,ResultSet rs){    if(rs!=null){//关闭资源,避免出现异常      try {        rs.close();      } catch (SQLException e) {        // TODO Auto-generated catch block        e.printStackTrace();      }    }    if(ps!=null){      try {        ps.close();      } catch (SQLException e) {        // TODO Auto-generated catch block        e.printStackTrace();      }    }    if(con!=null){      try {        con.close();      } catch (SQLException e) {        // TODO Auto-generated catch block        e.printStackTrace();      }    }  }    public static boolean addUpdateDelete(String sql,Object[] arr){    Connection con=null;    PreparedStatement ps=null;    try {      con=BaseDao.getCon();//第一步 :连接数据库的操作      ps=con.prepareStatement(sql);//第二步:预编译      //第三步:设置值      if(arr!=null && arr.length!=0){        for(int i=0;i<arr.length;i++){          ps.setObject(i+1, arr[i]);        }      }      int count=ps.executeUpdate();//第四步:执行sql语句      if(count>0){        return true;      }else{        return false;      }    } catch (ClassNotFoundException e) {      // TODO Auto-generated catch block      e.printStackTrace();    } catch (SQLException e) {      // TODO Auto-generated catch block      e.printStackTrace();    }    return false;  }  }

6. 这里直接在主方法里面进行了测试,所以写了UserDao进行测试,看效果即可。

package com.bie.dao;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;import com.bie.utils.BaseDao;public class UserDao {    public static void main(String[] args) {    Connection con=null;    PreparedStatement ps1=null;    PreparedStatement ps2=null;    try {      //第一步:连接数据库的操作      con=BaseDao.getCon();      //默认自动提交事务,所以默认是true,现在将true改为false,禁止默认自动提交事务      //con.setAutoCommit(true);      //事务1:如果设置为false,则需要手动提交事务      con.setAutoCommit(false);      //第二步:更新的sql语句      String sql="update bank_a set usera_rmb=usera_rmb-500 where usera_id=1 ";      String sql2="update bank_b set userb_rmb=userb_rmb+500 where userb_id=1 ";      //第三步:预编译sql      ps1=con.prepareStatement(sql);      //第四步:执行sql语句,虽然执行了sql,但是还没持久化更新到数据库      ps1.executeUpdate();      //第三步:预编译sql2      ps2=con.prepareStatement(sql2);      //第四步:执行sql2,虽然执行了sql2,但是还没持久化更新到数据库      ps2.executeUpdate();      System.out.println("转账成功...");      //事务2:手动提交事务,如果两个都执行成功了,那么提交事务      con.commit();    } catch (ClassNotFoundException e) {      e.printStackTrace();      try {        //事务3:如果抛出异常,那么回滚事务        con.rollback();      } catch (SQLException e1) {        e1.printStackTrace();      }    } catch (SQLException e) {      e.printStackTrace();    }finally {      //关闭资源,避免出现异常      BaseDao.close(con, ps1, null);      BaseDao.close(null, ps2, null);    }  }}

到此这篇关于怎么在Java中利用JDBC实现一个事务功能的文章就介绍到这了,更多相关的内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 怎么在Java中利用JDBC实现一个事务功能

本文链接: https://www.lsjlt.com/news/219955.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在Java中利用JDBC实现一个事务功能
    本文章向大家介绍怎么在Java中利用JDBC实现一个事务功能,主要包括怎么在Java中利用JDBC实现一个事务功能的使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。Java是什么Java是一门面...
    99+
    2023-05-30
  • 怎么在java中使用JDBC实现一个验证登录功能
    怎么在java中使用JDBC实现一个验证登录功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。java基本数据类型有哪些Java的基本数据类型分为:1、整数类型,用来表示整...
    99+
    2023-06-14
  • 利用Java怎么实现一个画板功能
    今天就跟大家聊聊有关利用Java怎么实现一个画板功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。基本的思路是这样的:画板实现大致分三部分:一是画板界面的实现,二是画板的监听以及画图...
    99+
    2023-05-31
    java ava
  • 怎么在Java中利用JavaMail实现一个邮件发送功能
    这期内容当中小编将会给大家带来有关怎么在Java中利用JavaMail实现一个邮件发送功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1. 电子邮件协议电子邮件的在网络中传输和网页一样需要遵从特定的协议...
    99+
    2023-05-31
    java javamail ava
  • 怎么在Java中利用JScrollPane实现一个面板滚动功能
    这篇文章将为大家详细讲解有关怎么在Java中利用JScrollPane实现一个面板滚动功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。       ...
    99+
    2023-05-31
    java jscrollpane ava
  • 怎么在Java中利用JUnit实现一个单元测试功能
    怎么在Java中利用JUnit实现一个单元测试功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。单元测试是编写测试代码,应该准确、快速地保证程序基本模块的正确性...
    99+
    2023-05-31
    java junit ava
  • 怎么在java中实现一个sleep功能
    这篇文章给大家介绍怎么在java中实现一个sleep功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端开发;4. 网页开...
    99+
    2023-06-14
  • 利用java怎么实现一个倒计时功能
    这期内容当中小编将会给大家带来有关利用java怎么实现一个倒计时功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。代码如下:package timer;import java.util.Calendar;...
    99+
    2023-05-31
    java ava
  • 使用Java怎么实现一个记事本功能
    今天就跟大家聊聊有关使用Java怎么实现一个记事本功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。源码: import java.awt.*; import java.awt.ev...
    99+
    2023-05-31
    java ava
  • 怎么在SpringBoot中利用WebSocket实现一个群聊功能
    本篇文章为大家展示了怎么在SpringBoot中利用WebSocket实现一个群聊功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。消息群发创建新项目:添加依赖:<dependency>...
    99+
    2023-06-06
  • 怎么在Android中利用IntentUtil实现一个跳转功能
    本文章向大家介绍怎么在Android中利用IntentUtil实现一个跳转功能的基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。Android是什么Android是一种基于Linux内核的自由及开放源代码的操作系统...
    99+
    2023-05-30
    android intentutil
  • 怎么在Centos中利用文件实现一个swap功能
    怎么在Centos中利用文件实现一个swap功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。创建swap文件mkdir/var/swap#创建一个文件夹用于存放交换分区文件,...
    99+
    2023-06-10
  • 怎么在html5中利用canvas实现一个弹幕功能
    本篇文章为大家展示了怎么在html5中利用canvas实现一个弹幕功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。(function () {   ...
    99+
    2023-06-09
  • 利用Java怎么实现一个邮箱激活功能
    利用Java怎么实现一个邮箱激活功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。实现思路注册时填写邮箱,点击注册时网站系统邮箱发送激活验证链接到此邮箱,用户来激活账户点击...
    99+
    2023-05-31
    java ava
  • 利用Java怎么实现一个单词提取功能
    这篇文章给大家介绍利用Java怎么实现一个单词提取功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。实现方法如下:package fanyi;import java.util.Scanner;import java.u...
    99+
    2023-05-30
    java ava
  • 利用java怎么实现一个四舍五入功能
    这期内容当中小编将会给大家带来有关利用java怎么实现一个四舍五入功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。四舍五入是我们小学的数学问题,这个问题对于我们程序猿来说就类似于1到10的加减乘除那么简...
    99+
    2023-05-31
    java ava
  • 利用java怎么实现一个即时提交功能
    本篇文章给大家分享的是有关利用java怎么实现一个即时提交功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。具体内容如下package com.tian.batis;impor...
    99+
    2023-05-31
    java ava
  • 利用java怎么实现一个网页爬虫功能
    利用java怎么实现一个网页爬虫功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。爬虫实现原理网络爬虫基本技术处理网络爬虫是数据采集的一种方法,实际项目开发中,通过爬虫做数...
    99+
    2023-05-31
    java ava
  • 利用java怎么实现一个动态加载功能
    今天就跟大家聊聊有关利用java怎么实现一个动态加载功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java动态加载类的意义和目的:Java动态加载类主要是为了不改变主程序代码,通...
    99+
    2023-05-31
    java ava
  • 怎么在Java项目中利用QuickSort实现一个快速排序功能
    今天就跟大家聊聊有关怎么在Java项目中利用QuickSort实现一个快速排序功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。快速排序-----------------------...
    99+
    2023-05-31
    quicksort java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作