连接池笔记\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再去读,数据变多了

相关推荐
安冬的码畜日常13 分钟前
【Vim Masterclass 笔记24】S10L43 + L44:同步练习10 —— 基于 Vim 缓冲区的各类基础操作练习(含点评课)
笔记·vim·自学笔记·vim同步练习·vim缓冲区·vim buffer·vim缓冲区练习
一只码代码的章鱼22 分钟前
粒子群算法 笔记 数学建模
笔记·算法·数学建模·逻辑回归
圆圆滚滚小企鹅。28 分钟前
刷题笔记 贪心算法-1 贪心算法理论基础
笔记·算法·leetcode·贪心算法
杨过姑父44 分钟前
ES6 简单练习笔记--变量申明
前端·笔记·es6
l1x1n01 小时前
No.37 笔记 | Python面向对象编程学习笔记:探索代码世界的奇妙之旅
笔记·python·学习
路上阡陌1 小时前
Java学习笔记(二十四)
java·笔记·学习
束照2 小时前
noteboolm 使用笔记
笔记·notebooklm
安冬的码畜日常2 小时前
【Vim Masterclass 笔记23】第十章:Vim 缓冲区与多窗口的用法概述 + S10L42:Vim 缓冲区的用法详解与多文件编辑
笔记·vim·buffer·vim缓冲区·vim buffer·vim多文件编辑·vim多文件
初九之潜龙勿用3 小时前
我的创作纪念日,纪念我的第512天
笔记
雾里看山5 小时前
【MySQL】 库的操作
android·数据库·笔记·mysql