连接池笔记\JDBC的API\ACID属性\数据并发问题

2024-05-24 21:36

本文主要是介绍连接池笔记\JDBC的API\ACID属性\数据并发问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1-池化思想
字符串常量池、数据库连接池、线程池
频繁使用的东西,不要每次都去创建
没连接池之前:
(1)获取连接
(2)进行sql操作
(3)断开连接
存在问题
(1)每次都要加载对象,验证账号密码、连接、断开消耗资源
(2)非常多人连接断开,可能会导致服务器崩溃
(3)不能管理创建的连接对象,分配资源没有管理能力,可能导致内存泄漏服务崩溃

连接池概述
(1)是个容器,可以管理连接
(2)可以重复使用现有连接
(3)长时间不用会关闭

连接池实现
用DataSource接口实现,接口定义了连接功能,第三方实现接口

常用连接池
DBCP
C3P0
Druid(德鲁伊) 阿里提供的

2-数据持久化
把数据保存到永久保存的设备中

3-java中的数据存储
(1)序列化与反序列化
(2)操作数据库(增、删、改、查)

4-java如何操作数据库
(1)通过jdbc直接访问
(2)第三方o/r工具(mybatis)
(3)JDBC是底层的原理

5-JDBC是操作数据库的Api,定义了操作数据库的规范

6-java->jdbc->数据库驱动->数据库

7-有了JDBC之后,不同的数据库根据JDBC规范,可以操作数据库。

8-JDBC的API
(1)DriverManager:驱动管理
(2)Connection:数据库连接对象
(3)Statement:执行sql语句
(4)ResultSet:结果集对象
过程:写java代码,java代码将sql语句发送到mysql服务器,mysql数据库接收sql语句处理,将结果返回
9-导入包
选择版本:到maven仓库https://mvnrepository.com/artifact/com.oracle.database.jdbc/,输入mysql-connect(oracle-connect),选择一个后点进详情页,前面数字是数据库的版本号,选择使用多的下载。
10-JDBC事务操作
事务的ACID属性
(1)原子性:不可分割,要么同时失败,要么同时成功
(2)一致性:事务必须使数据库从一个一致性状态转为另一个一致性状态
(3)隔离性:事务之间互不干扰
(4)持久性:事务的操作是永久性的

11-数据并发问题
(1)脏读:A事务读到B事务没有提交的
(2)不可重读:A事务先读到的值,被B事务更改了
(3)幻读:A读所有,B再插入新的,A再去读,数据变多了

这篇关于连接池笔记\JDBC的API\ACID属性\数据并发问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/999589

相关文章

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错

如何解决Spring MVC中响应乱码问题

《如何解决SpringMVC中响应乱码问题》:本文主要介绍如何解决SpringMVC中响应乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC最新响应中乱码解决方式以前的解决办法这是比较通用的一种方法总结Spring MVC最新响应中乱码解