03 事务,连接池DBCP,C3P0,DBUtils】的更多相关文章

1. 连接池 思考: 程序中连接如何管理? 连接资源宝贵:需要对连接管理 连接: a) 操作数据库,创建连接 b) 操作结束,  关闭! 分析: 涉及频繁的连接的打开.关闭,影响程序的运行效率! 连接管理: 预先创建一组连接,有的时候每次取出一个: 用完后,放回: 学习连接池: 自定义一个连接池 学习优秀的连接池组件 a) DBCP b) C3P0 自定义连接池 代理: 如果对某个接口中的某个指定的方法的功能进行扩展,而不想实现接口里所有方法,可以使用(动态)代理模式! Java中代理模式:静态…
介绍 因为数据库连接对象的创建比较消耗性能,所以可以在应用程序启动时就在内存中开辟一片空间(集合)存放多个数据库连接对象,后面需要连接时直接从该空间中取而不用新创建:使用完毕后归还连接(将连接重新放回空间),确保连接对象能重复使用. 知识储备 装饰者模式 package com.zze.test; public interface IWaiter { void service(); } IWaiter.java package com.zze.test; public class Waiter…
1.事务 ACID 原子性 一致性 隔离性 持久性 mysql中开启和关闭事务 开启事务:START TRANSACTION 结束事务 提交事务:COMMIT 回滚事务:ROLLBACK JDBC中开启和关闭事务 开启事务:connection.setAutoCommit(false) 结束事务 connection.commit() connection.rollback() 三种并发读问题 脏读 不可重复读 幻读 四种隔离级别 串行化 可重复读 读已提交 读未提交 2.连接池 必须实现jav…
day18总结 今日思维导图: 今日内容 事务 连接池 ThreadLocal BaseServlet自定义Servlet父类(只要求会用,不要求会写) DBUtils à commons-dbutils   事务   事务的四大特性:ACID: mysql中操作事务 jdbc中操作事务       事务概述 为了方便演示事务,我们需要创建一个account表: CREATE TABLE account(     id INT PRIMARY KEY AUTO_INCREMENT,     NA…
1.   DBCP连接池…
jdbc数据连接池dbcp要导入的jar包 只用导入commons-dbcp-x.y.z.jarcommons-pool-a.b.jar…
连接池dbcp DBCP:apache组织 使用步骤: 1.导入jar包(commons-dbcp-1.4.jar和commons-pool-1.5.6.jar.commons-logging-1.2.jar) 2.使用api a.硬编码 //创建连接池 BasicDataSource ds = new BasicDataSource(); //配置信息 ds.setDriverClassName("com.mysql.jdbc.Driver"); ds.setUrl("jd…
事务 Transaction  其实指的一组操作,里面包含许多个单一的逻辑.只要有一个逻辑没有执行成功,那么都算失败. 所有的数据都回归到最初的状态(回滚) 事务的作用:为了确保逻辑的成功. 例子: 银行的转账. 命令行方式:开启事务    start transaction;提交或者回滚事务    commit; 提交事务, 数据将会写到磁盘上的数据库    rollback ;  数据回滚,回到最初的状态.关闭自动提交功能show variable like '%commit%';查看aut…
Jar包使用,及层的划分 c3p0-config.xml <?xml version="1.0" encoding="UTF-8"?> <c3p0-config> <!-- 默认配置,如果没有指定则使用这个配置 默认配置最常用 建议放在最开头. 放其他地方也没问题 --> <default-config> <property name="driverClass">com.mysql.jd…
首先看C3p0这个连接池,最大优势可以自动读取默认的配置文件 <?xml version="1.0" encoding="UTF-8"?> <c3p0-config> <default-config> <property name="driverClass">com.mysql.jdbc.Driver</property> <property name="jdbcUrl&…