MySQL-事务,properties文件解析,连接池

1.事务机制管理

        1.1 Transaction事务机制管理

        默认情况下是执行一条sql语句就保存一次,那么比如我们需要三条数据同时成功或同时失败就需要开启事务机制了。开启事务机制后执行过程中发生问题就会回滚到操作之前,相当于没有执行操作。

        1.2 事务的特征

                事务具有四个基本特性,通常称为ACID特性,分别是:

                原子性(Atomicity):原子性指的是事务是不可分割的最小执行单元。事务中的所有操作要么全部提交成功,要么全部失败回滚,不存在部分提交或部分回滚的情况。原子性确保了数据库在执行事务时的完整性,即要么所有操作都成功,要么都不影响数据库状态。

                一致性(Consistency):一致性指的是事务执行前后,数据库的状态必须保持一致。事务执行过程中可能改变数据库中的数据,但是这些改变必须满足数据库定义的所有约束和规则,确保数据库从一个一致性状态转换到另一个一致性状态。

                隔离性(Isolation):隔离性指的是并发执行的多个事务之间是相互隔离的,一个事务的执行不应该受到其他事务的影响。隔离性保证了每个事务在执行时都拥有独立的数据空间,不会互相干扰,避免了并发事务之间的数据竞争和不一致性问题。

                持久性(Durability):持久性指的是一旦事务提交成功,其所做的修改将永久保存在数据库中,并且不会因系统故障而丢失。即使系统崩溃或断电,已提交的事务对数据库的修改也应该被永久保存。持久性确保了数据的可靠性和持久性,是数据库系统的重要特性之一。

                这些特性确保了事务在数据库中的可靠性、一致性和完整性,是数据库管理系统实现数据管理和控制的基础。

        1.3 事务处理操作
public class JDBC_Transction {
	public static void main(String[] args) {
		// noTransaction();
		useTransaction();
	}

	// 未使用事务
	// 当第二个sql语句有错误时,一三语句同样会执行
	public static void noTransaction() {
		Connection conn = null;
		Statement statement = null;
		try {
			conn = DBUtil.getConnection();
			statement = conn.createStatement();

			statement.addBatch("insert into user(name,password,nickname) values('test1',111,'用户1')");
			statement.addBatch("insert into user(name,pass,nickname) values('test2',222,'用户2')");
			statement.addBatch("insert into user(name,password,nickname) values('test3',333,'用户3')");
			statement.executeBatch();
			System.out.println("添加成功");

		} catch (ClassNotFoundException | SQLException e) {
			e.printStackTrace();
		} finally {
			DBUtil.close(statement);
			DBUtil.close(conn);
		}
	}

	// 使用事务
	// 第二句sql语句有错,第一三条数据也不会执行
	public static void useTransaction() {
		Connection conn = null;
		Statement statement = null;
		try {
			conn = DBUtil.getConnection();
			statement = conn.createStatement();
			// 关闭自动提交,开启事务
			conn.setAutoCommit(false);

			statement.addBatch("insert into user(name,password,nickname) values('test1',111,'用户1')");
			statement.addBatch("insert into user(name,pass,nickname) values('test2',222,'用户2')");
			statement.addBatch("insert into user(name,password,nickname) values('test3',333,'用户3')");
			statement.executeBatch();

			// 执行完成后,提交并开启自动提交
			conn.commit();
			conn.setAutoCommit(true);
			System.out.println("添加成功");

		} catch (ClassNotFoundException | SQLException e) {
			e.printStackTrace();
			// 执行到这里说明有错
			if (conn != null) {
				try {
					// 事务回滚,回到操作之前的状态
					// 同时删除操作对应的缓冲区中的数据
					conn.rollback();
				} catch (SQLException e1) {
					e1.printStackTrace();
				}
			}
		} finally {
			DBUtil.close(statement);
			DBUtil.close(conn);
		}
	}

}

        2.Properties优化硬编码

public static Connection getConnection() throws ClassNotFoundException, SQLException{
		Class.forName("com.mysql.cj.jdbc.Driver");
		Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/_day_02","root", "abc280619SS");
		return conn;
	}

        如上代码,我们项目开发完成测试通过后,通常是要打包发布给别人使用的,如果我们把一些配置信息写死到代码中(这种行为叫硬编码,hardcode),别人就无法修改了

        比如别人使用的MySQL服务器对应的IP是10.0.0.1,端口号是9300,用户名是mysqluser、密码是123456。

        那么我们只能改代码再重新打包发布,如果有多个用户,他们对应的配置信息都不同,那么我们要针对不同的用户打包发布多次。

        以上显然是没必要的,因为我们开发的是程序,只要业务需求/逻辑不变,我们就无需多次打包发布。对此我们的解决方案是,尽量避免硬编码,      将数据与程序分离解耦,将配置信息存储到配置文件中,程序运行时读取配置文件,不同用户只需按自己的实际情况修改配置文件即可。

        2.1 创建jdbc.properties文件

这种方式下,账号密码发生变动时,只需要更改配置文件中的内容即可。

driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/_day_02
username=root
password=root
        2.2 创建PropertiesUtil
public class PropertieUtil {
	private static Properties properties = null;
	static {
		try {
			// propertie 本质就是一个map,可以通过key获取value
			properties = new Properties();
			properties.load(Properties.class.getClassLoader().getResourceAsStream("jdbc.properties"));
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	// 提供获取value的方法
	public static String get(String key) {
		return properties.getProperty(key);
	}
}
        2.3 更改DBUtil工具类
public class DBUtil_00 {
	// 封装方法加载驱动创建链接
		public static Connection getConnection() throws ClassNotFoundException, SQLException{
			// 通过PropertiesUtil获取配置文件中的值
			Class.forName(PropertieUtil.get("driver"));
			String url = PropertieUtil.get("url");
			String username = PropertieUtil.get("username");
			String password = PropertieUtil.get("password");
			Connection conn = DriverManager.getConnection(url,username,password);
			return conn;
		}
		// 封装方法关闭资源
		public static void close(AutoCloseable obj) {
			if (obj != null) {
				try {
					obj.close();
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
		}
}

        3. 连接池

        3.1 介绍

                数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个;

                释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。

                这项技术能明显提高对数据库操作的性能。

        3.2 应用场景

                场景一:电商网站如淘宝,京东的双十一活动,同一时刻会有上亿甚至上十亿的用户访问数据库。

                场景二:某服务器上除了运行MYSQL服务,还有其他一些服务比如WEB服务。我们知道,数据库连接的创建维持不只消耗我们客户端(个人PC)的系统资源(CPU、内存、IO设备),更消耗服务器的系统资源,而假如我们在周末时并不会去访问数据库,这时候服务器上依然还维持着一条空闲的连接,假设占用了2M内存,现在服务器上内存已经都被分配出去了,WEB服务却要求新申请1M内存,很显然,由于内存不足,WEB服务就无法正常运行了。

                以上两种情况下,如果只使用上面的代码是无法支持的。连接池的引入,则主要解决了以上两类问题:

                1. 能给多用户分配链接或给一个用户分配多个链接

                2. 在适当的时候回收空闲链接以节省系统资源

                

                JDBC连接池有一个对应的接口javax.sql.DataSource。它也是一个标准一个规范,目前实现了这套规范的连接池产品主要有:DBCP(MyBatis通常使用这个连接池)、C3P0(Hibernate通常使用这个连接池)、JNDI(Tomcat的默认连接池)。

                以DBCP为例:

                DBCP内部提供了一个“池子”,程序启动的时候,先创建一些连接对象放到这个池子中,备用,当调用连接池的getConnection()方法时,就从池子取出连接对象分配给多个用户/线程。使用完毕调用close()方法时,DBCP重写了close方法,它并不真正关闭连接,而是返还到池子中,由DBCP自动管理池子中的连接对象,在适当的时候真正关闭这些连接。

        优点 :

        资源复用 : 数据库连接得到重用,避免了频繁创建释放链接引起的大量性能开销,在减少系统消耗的基础上,也增进了系统运行环境的平稳性

        更快的系统响应速度 : 数据库连接池在初始化过程中,往往就已经创建了若干个数据库连接对象放到池中备用。这时,连接的初始化工作已完成,对于业务请求处理而言,直接利用现有的可用连接,避免了数据库连接初始化和释放过程的时间,从而缩减了系统整体的响应时间

        统一的连接管理,避免数据库连接遗漏 : 在较为完备数据库连接池中,可以根据预先的连接占用超时设定,强制回收占用连接,从而避免了常规数据库连接操作中可能出现的资源泄露情况

        因为连接池组件不是JDK自带的,所以要导入相关jar包,DBCP相关的吉安人、

包有三个,如下:

        3.3 创建连接池工具类
public class BasicDataSorceUtil {
	private static BasicDataSource basicDataSource;
	
	// 为了解决高并发的问题,使用线程安全的单例模式,以双重锁校验的懒汉模式为例
	// 提供获取线程池对象的方法
	public static BasicDataSource getBasicDataSource() {
		if (basicDataSource == null) {
			synchronized (BasicDataSource.class) {
				if (basicDataSource == null) {
					basicDataSource = new BasicDataSource();
					basicDataSource.setDriverClassName(PropertieUtil.get("driver"));
					basicDataSource.setUrl(PropertieUtil.get("url"));
					basicDataSource.setUsername(PropertieUtil.get("username"));
					basicDataSource.setPassword(PropertieUtil.get("password"));
				}
			}
		}
		return basicDataSource;
	}
}
        3.4 测试线程池链接
// 使用数据库连接池
public class DBUtil_01 {
	public static void main(String[] args) throws SQLException {
		// 获取连接池对象
		BasicDataSource bds = BasicDataSorceUtil.getBasicDataSource();
		// 通过连接池获取链接对象
		Connection conn = bds.getConnection();
		
		PreparedStatement ps = conn.
				prepareStatement("insert into user(name,password,nickname) values('test4',444,'用户4')");
		ps.executeUpdate();
		ps.close();
		conn.close();
	}
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

sql-labs25-28a

一、环境 网上都有不过多阐述 二、sql-labs第25关 它说你的OR和and属于它,那就是过滤了OR和and 注入尝试 不用or和and进行爆破注入,很明显是有注入点的 ?id-1 union select 1,2,3-- 查看数据库 ok,此道题算是解了但是如果我们用了and了呢 ?id-1 and updatex…

消息中间件篇之Kafka-高性能设计

一、高性能设计 消息分区:不受单台服务器的限制,可以不受限的处理更多的数据。 顺序读写:磁盘顺序读写,提升读写效率。 页缓存:把磁盘中的数据缓存到内存中,把对磁盘的访问变为对内存的访问。 零拷贝&a…

C# 水排序 微信小游戏

来只 水排序谜题启发式搜索方法_水排序解法小程序-CSDN博客 大神的C语言转换成C# 语言,更多的请看原作者,这里直接贴C#代码 using System; using System.Collections.Generic; using System.Linq; using System.Text;namespace ConsoleApp2 {class Pro…

SImpAl

output matrix M,Curriculum using w ( x t , f , h ) w(x_t, f, h) w(xt​,f,h) 辅助信息 作者未提供代码

想露一手Linux命令,掌握这20个够用了!

中午好,我的网工朋友。 想做好网工,除了路由交换,掌握Linux操作系统也是很重要的。 因为很多服务器上都是用的Linux系统,要和服务器机器交互,就要通过Linux的相关命令。 正在找工作的朋友,如果面试时&am…

thinkphp6定时任务

这里主要是教没有用过定时任务没有头绪的朋友, 定时任务可以处理一些定时备份数据库等一系列操作, 具体根据自己的业务逻辑进行更改 直接上代码 首先, 是先在 tp 中的 command 方法中声明, 如果没有就自己新建一个, 代码如下 然后就是写你的业务逻辑 执行定时任务 方法写好了…

leetcode 2867. 统计树中的合法路径数目【筛质数+贡献法】

原题链接:2867. 统计树中的合法路径数目 题目描述: 给你一棵 n 个节点的无向树,节点编号为 1 到 n 。给你一个整数 n 和一个长度为 n - 1 的二维整数数组 edges ,其中 edges[i] [ui, vi] 表示节点 ui 和 vi 在树中有一条边。 …

openai sora 只能根据文本生成视频?不,TA 是通用物理世界模拟器

视频生成模型作为世界模拟器 我们探索了在视频数据上进行大规模生成模型的训练。 具体来说,我们联合在可变持续时间、分辨率和长宽比的视频和图像上训练文本条件扩散模型。 我们利用了一个在视频和图像潜在编码的时空补丁上操作的变压器架构。 我们最大的模型So…

请求包的大小会影响Redis每秒处理请求数量

文章目录 🔊博主介绍🥤本文内容压测规划客户端长连接数量对性能的影响请求包大小的影响Pipleline模式对Redis的影响 📢文章总结📥博主目标 🔊博主介绍 🌟我是廖志伟,一名Java开发工程师、Java领…

CG-0A 电子水尺可实现对水位数据的连续自动监测

CG-0A 电子水尺可实现对水位数据的连续自动监测产品概述 本产品是一种采用微处理器芯片为控制器,内置通讯电路的数字式水位传感器,具备高的可靠性及抗干扰性能。适用于江、河、湖、水库及蓄水池、水渠等处的水位测量使用。 本产品采用了生产工艺技术&…

springboot集成kafka快速入门demo

一、kafka介绍 Kafka是一种基于分布式发布-订阅消息系统的开源软件。 其目标是提供高吞吐量、低延迟、可扩展性和容错能力。 Kafka中将消息存储在可配置数量的分区中,以便实现横向扩展,并且支持多个生产者和消费者,具有良好的可靠性保证机制。…

【精选】Java面向对象进阶——静态内部类和局部内部类

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~ ✨主攻领域:【渗透领域】【应急响应】 【Java】 【VulnHub靶场复现】【面试分析】 🎉点赞➕评论➕收藏 …

SpringCloud有哪些组件

什么是SpringCloud? Spring Cloud是基于Spring Boot的分布式系统开发工具,它提供了一系列开箱即用的、针对分布式系统开发的特性和组件,用于帮助开发人员快速构建和管理云原生应用程序。 Spring Cloud的主要目标是解决分布式系统中的常见问题…

FL Studio Fruity Edition2024中文入门版Win/Mac

FL Studio Fruity Edition2024是一款功能强大的音乐制作软件,适合初学者和音乐爱好者使用。它提供了丰富的音乐制作工具,包括音频录制、编辑、混音以及MIDI制作等功能,帮助用户轻松创作出动人的音乐作品。 FL Studio 21.2.3 Win-安装包下载如…

Linux之定时任务①(实施必会!!!)

文章目录 常见脚本一、 什么是crond二、crond的使用场景一、apache服务器监控三、crond服务四、命令格式五、cron格式六、定时任务备份七、数据库定时备份八、使用shell脚本发送邮件 常见脚本 [rootlocalhost ~]# vim apacheSentry.sh#!/bin/bash # author: tt # description:…

DAY34--learning English

一、积累 1.listless 2.sanction 3.inflict 4.stung 5.droplet 6.rot 7.soil 8.welfare 9.flock 10.mitigate 11.incubation 12.feces 13.urine 14.odor 15.sprinkle 16.guresome 17.slaughter 18.antibiotic 19.certify 20.tray 二、练习 1.牛津原译 Listless adj. /ˈlɪst…

【毛毛讲书】【老而不衰的科学】长寿的秘诀究竟是什么?

重磅推荐专栏: 《大模型AIGC》 《课程大纲》 《知识星球》 本专栏致力于探索和讨论当今最前沿的技术趋势和应用领域,包括但不限于ChatGPT和Stable Diffusion等。我们将深入研究大型模型的开发和应用,以及与之相关的人工智能生成内容&#xff…

用GGUF和Llama .cpp量化Llama模型

用GGUF和Llama .cpp量化Llama模型 什么是GGML如何用GGML量化llm使用GGML进行量化NF4 vs. GGML vs. GPTQ结论 由于大型语言模型(LLMS)的庞大规模,量化已成为有效运行它们的必要技术。通过降低其权重的精度,您可以节省内存并加快推理…

IP 电话

1 IP 电话概述 IP 电话是在互联网上传送多媒体信息。 多个英文同义词: VoIP (Voice over IP) Internet Telephony VON (Voice On the Net) 1.1 狭义的和广义的 IP 电话 狭义的 IP 电话:指在 IP 网络上打电话。 广义的 IP 电话:不仅仅是…

二 线性代数-向量

1、向量的表示方法: 其中的 i、j、k是坐标轴方向的单位向量。 2、向量的模: 用坐标计算的方法: 3、向量的运算: 3.1 向量的加法减法: 3.2 向量的数乘: 拉格朗日乘数法的 基础 公式。 3.3 向量的数量积&a…