mysql事务与jdbc事务_事务(mysql事务、jdbc事务)

一、MYSQL事务

1、事务

概念:事务是一个用户定义的数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。事务可以是一条sql语句,一组sqi语句或者整个程序。

特性(ACDI):

(1)原子性:一个事务中的操作要么全做,要么全不做。

(2)一致性:事务执行的结果必须使数据库从一个一致性状态转换为另一个一致性状态。

(3)隔离性:并发执行的事务之间互不干扰。

(4)持久性:一个事务一旦提交对数据库的操作就是永久性的。(已经存储到了磁盘)

2、MYSQL的事务:

(1)如果用户不对数据库进行操作,默认情况下事务直接开始并提交(将对数据库的更新写到磁盘)。

例如:在login数据表中执行以下插入操作后:

INSERT login VALUES('mysql','事务')

88e6c0c5180061ee575b6ad025acad7e.png

执行查询语句后,数据库中已经存在数据。

(2)手动操作事务的开始和提交:

先开启事务:

START TRANSACTION

执行插入语句:

INSERT login VALUES('星期一','Monday')

此时执行查询语句,依旧能够查询到插入的数据:

2e9a1e1f7e9cfb70b4a76ecfe7e3adac.png

但是,此时并未对事务进行提交操作,数据并未进入磁盘。

如果执行回滚语句,插入的数据将会消失(从事务开启到回滚之间的操作均被撤销):

ROLLBACK

但是,如果执行的是提交语句,数据将会被写入磁盘。

二、JDBC事务

1、自动提交方式,即不手动操作,只适用于对数据库的更新操作

创建JavaBean:

package pers.zhb.domain;

public classStudent {

privateString studentno;

privateString sname;

privateString sex; privateString birthday; privateString classno; privateString point; privateString phone; privateString email; publicString getStudentno() { returnstudentno; } public voidsetStudentno(String studentno) { this.studentno =studentno; } publicString getSname() { returnsname; } public voidsetSname(String sname) { this.sname =sname; } publicString getSex() { returnsex; } public voidsetSex(String sex) { this.sex =sex; } publicString getBirthday() { returnbirthday; } public voidsetBirthday(String birthday) { this.birthday =birthday; } @Override publicString toString() { return "Student [studentno=" + studentno + ", sname=" + sname + ", sex=" + sex + ", birthday=" + birthday + ", classno=" +classno + ", point=" + point + ", phone=" + phone + ", email=" +email + "]"; } publicString getClassno() { returnclassno; } public voidsetClassno(String classno) { this.classno =classno; } publicString getPoint() { returnpoint; } public voidsetPoint(String point) { this.point =point; } publicString getPhone() { returnphone; } public voidsetPhone(String phone) { this.phone =phone; } publicString getEmail() { returnemail; } public voidsetEmail(String email) { this.email =email; } }

不设置对事务的提交方式:

package pers.zhb.test;

import org.apache.commons.dbutils.QueryRunner;

import pers.zhb.dbutils.*;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

public classTest{

public static voidmain(String[] args){

Connection con = null; PreparedStatement ps = null; ResultSet rs = null; try{ con = c3p0Utiils.getConnection();//从连接池中获取连接 //con.setAutoCommit(false);//设置为手动提交事务的方式 QueryRunner qr = newQueryRunner(); String sql = "INSERT INTO student(studentno,sname,sex,birthday,classno,point,phone,email) VALUES(?,?,?,?,?,?,?,?)"; Object[] params = { "20191813", "huab", "男", "1988-12-01", "201901", "239", "16623540978", "Tom.@3218n.com"}; int num = qr.update(con, sql, params); //con.commit(); } catch(Exception e) { e.printStackTrace(); } finally{ c3p0Utiils.close(con, null, rs); } } }

2、手动提交方式:

package pers.zhb.test;

import org.apache.commons.dbutils.QueryRunner;

import pers.zhb.dbutils.*;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

public classTest{

public static voidmain(String[] args){

Connection con = null; PreparedStatement ps = null; ResultSet rs = null; try{ con = c3p0Utiils.getConnection();//从连接池中获取连接 con.setAutoCommit(false);//设置为手动提交事务的方式 QueryRunner qr = newQueryRunner(); String sql = "INSERT INTO student(studentno,sname,sex,birthday,classno,point,phone,email) VALUES(?,?,?,?,?,?,?,?)"; Object[] params = { "20191815", "huab", "男", "1988-12-01", "201901", "239", "16623540978", "Tom.@3218n.com"}; int num = qr.update(con, sql, params); con.commit(); } catch(Exception e) { e.printStackTrace(); } finally{ c3p0Utiils.close(con, null, rs); } } }

不提交的话,数据库中是没有数据的。

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

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

相关文章

access 如何使用dolby_Access/VBA/Excel-Access表及字段创建-03

Part 1:前面的话对Access数据库的大部分操作都可以通过SQL语言来实现SQL:Structure Query Language,结构化查询语言,语法简单,非常容易学SQL语言的执行可借助于ADO,ADO本身也支持对数据库的各种操作,但是涉…

LeetCode 1937. 扣分后的最大得分(动态规划)

文章目录1. 题目2. 解题1. 题目 给你一个 m x n 的整数矩阵 points (下标从 0 开始)。 一开始你的得分为 0 ,你想最大化从矩阵中得到的分数。 你的得分方式为:每一行 中选取一个格子,选中坐标为 (r, c) 的格子会给你…

java代码测试---插入排序和选择排序

1 public class QuickSort {2 3 //插入排序4 //插入前的序列是排序好的&#xff0c;将新插入的数值与之前的数值比较5 //直到找到合适的位置6 public static int[] quickSort(int[] arr){7 8 for(int j1;j<arr.length;j){9 …

mysql正则表达式配置_G. MySQL正则表达式

附录G&#xff1a;MySQL正则表达式正则表达式是为复杂搜索指定模式的强大方式。MySQL采用Henry Spencer的正则表达式实施&#xff0c;其目标是符合POSIX1003.2。请参见附录C&#xff1a;感谢。MySQL采用了扩展的版本&#xff0c;以支持在SQL语句中与REGEXP操作符一起使用的模式…

python列表appendtext_python-默认文本以及列表textvariable Entry小部...

为了将默认文本放在Entry小部件中,可以使用here所述的insert()方法.box.insert(0, "Value 1") # Set default text at cursor position 0.现在,为了在用户在框内单击鼠标后更改框的内容,您需要将事件绑定到Entry对象.例如,以下代码在单击该框时将其删除. (您可以阅读…

逻辑斯谛回归模型

逻辑斯谛回归模型是研究因变量为二分类或多分类观察结果与影响因素之间的关系的一种概率型非线性回归模型。逻辑斯谛回归系数通过最大似然估计得到。Logistic函数如下&#xff1a; 式中x为 这里是输入变量的n个特征&#xff0c;然后按照Logistic函数形式求出。 假设有n个独立变…

mysql监控平台怎么做_MySQL监控平台的构建方法

MySQL监控平台的构建方法发布时间&#xff1a;2020-05-23 14:13:12来源&#xff1a;亿速云阅读&#xff1a;159作者&#xff1a;鸽子概述对于MySQL的监控平台&#xff0c;相信大家实现起来有很多了&#xff1a;基于天兔的监控&#xff0c;还有基于zabbix相关的二次开发。相信很…

查看宝塔面板账号密码命令_宝塔面板升级到最新版图文教程

往期教程&#xff1a;宝塔面板教程&#xff08;1&#xff09;基于云服务器搭建宝塔面板教程最全详解宝塔面板教程&#xff08;2&#xff09;宝塔面板添加WordPress站点详细图文教程宝塔面板教程&#xff08;3&#xff09;基于宝塔面板成功配置网站SSL安全证书宝塔面板教程&…

python 对象引用、可变性 和 垃圾回收

文章目录1. 变量是标签2. 元组的相对不可变性3. 默认浅复制4. 函数的参数作为引用时5. del 和 垃圾回收6. 弱引用7. 一些可能的坑&#xff01;&#xff01;&#xff01;learn from 《流畅的python》 1. 变量是标签 >>> a [1, 2, 3] >>> b a >>&g…

关于原型的一点总结

原型&#xff08;prototype&#xff09;无疑是JavaScript中一个十分重要的概念&#xff0c;围绕着原型所涉及的原型链继承、内建对象扩展&#xff0c;JS表现出独特的面向对象特性。 1.什么是原型每个JS的函数对象中都有一个默认的prototype属性&#xff0c;它指向的就是这个函数…

python canopen_Python canopener包_程序模块 - PyPI - Python中文网

用于打开文件的python便利函数canopener(filename, moder)。本地文件的行为与open()&#xff1a;>>> canopener(local_file.txt)url也可以作为文件名传递并打开进行读取。urllib2.urlopen()是在封面下使用的&#xff0c;因此它具有同等的支持&#xff1a;>>>…

python自动化pdf报告_[Python] 自动化办公 PDF提取文字、表格、图片

转载请注明&#xff1a;陈熹 chenx6542foxmail.com (简书号&#xff1a;半为花间酒)若公众号内转载请联系公众号&#xff1a;早起Python本例可以学到的知识点&#xff1a;使用 pdfplumber 提取 PDF 中的文字和表格使用 fitz 提取 PDF 中的图片之前我们已经详细介绍了批量 PDF 文…

天池 在线编程 最长AB子串(哈希)

文章目录1. 题目2. 解题1. 题目 描述 给你一个只由字母’A’和’B’组成的字符串s&#xff0c;找一个最长的子串&#xff0c;要求这个子串里面’A’和’B’的数目相等&#xff0c;输出该子串的长度。 这个子串可以为空。 s的长度n满足 2<n<1000000。示例 样例1 输入: s…

Tomcat 打开一闪而过

转载于:https://www.cnblogs.com/super90/p/4504326.html

java怎么递归_Java的递归、如何与流相结合

递归技术需求&#xff1a;扫描D:\test所有子文件夹及子子文件夹下的.jpg文件。我们如果用循环来做这件事&#xff0c;我们不知道循环的结束条件&#xff0c;也不知道到底有多少层&#xff0c;所以比较麻烦。我们可以用一种新的思想&#xff1a;递归。递归举例&#xff1a;从前有…

假设有搅乱顺序的一群儿童成一个队列_数据结构与算法系列之栈amp;队列(GO)...

以下完整代码均可从这里获取栈栈的基本概念「后进先出、先进后出就是典型的栈结构」。栈可以理解成一种受了限制的线性表&#xff0c;插入和删除都只能从一端进行当某个数据集合只涉及在一端插入和删除数据&#xff0c;并且满足后进先出、先进后出的特性&#xff0c;就应该首选…

python 自定义类(特殊方法)

文章目录1. 对象表示形式2. 可散列的类3. 私有属性的利弊4. __slots__ 类属性节省空间5. 覆盖类属性learn from 《流畅的python》 from array import array import mathclass Vector2D:typecode d # 类属性def __init__(self, x, y):self.x float(x)self.y float(y)classm…

网络知识

http://www.cnblogs.com/dawen/archive/2011/05/18/2050358.html http://www.cnblogs.com/daoluanxiaozi/p/3274925.html转载于:https://www.cnblogs.com/webundle/p/4505782.html

datagridview 动态插入图片_挑战一张照片制作动态PPT背景

在PPT中&#xff0c;要做出好看的页面动画效果&#xff0c;常常需要用很多图片和装饰元素。而如果你手头的素材只有一张照片&#xff0c;如何才能快速做出好看的PPT背景效果呢&#xff1f;本期内容&#xff0c;我们就来一起挑战&#xff0c;使用一张照片&#xff0c;制作PPT动态…

sed搜索某行在行末追加_示范sed指定某行插入 追加和全局替换

有时候会有这样的需求&#xff0c;在指定的行后面或者是前面追加一行&#xff0c;这个时候可以使用sed来完成&#xff0c;具体用法如下a\ 在指定的行后面追加一行b\ 在指定的行前面追加一行使用指定的行号追加内容&#xff0c;在使用行号的过程中&#xff0c;需要注意的问题有以…