Java_09_15课堂总结
来源:互联网 发布:淘宝店铺资质1000元 编辑:程序博客网 时间:2024/05/21 22:40
MySQL事务、JDBC总结
一, 概括
在实际的应用中,很少只局限于对单表进行操作,通常会涉及多表操作。例如银行的取款操作,它至少需要两个步骤——首先进行取款操作,取款成功后更改账户金额;其次记录日志,记录此次取款的时间及金额等。这两个步骤是需要同时成功才算完成取款交易的。要完成上述的需求就需要借助于JDBC的事务管理和批量处理。
所谓事务:是指一组原子操作(一组SQL语句执行)的工作单元。
这个工作单元中的所有原子操作在进行期间,与其他事务隔离,免于因数据来源的交相更新而发生混乱,事务中的所有原子操作要么全部执行成功,要么全部失败。
二, 创建JDBC的事务主要分以下步骤:
a) 设置事务的提交方式为非自动提交:conn.setAutoCommit(false);
b) 将需要添加事务的代码放在try、catch块中:
try {
//需要添加事务的业务代码
} catch (SQLException e) {
...
}在try块内添加提交操作,表示操作无异常,提交事务:conn.commit(); //正常流程,提交事务
在catch块内添加回滚事务,表示操作出现异常,撤消事务:conn.rollback(); //发生异常,撤消事务
设置事务提交方式为自动提交:conn.setAutoCommit(true); //自动提交事务
三,JDBC批量处理
• Statement的execute()等方法一次只能执行一条SQL语句,如果同时有多条SQL语句要执行的话,可以使用addBatch()方法将要执行的SQL语句加入进来,然后执行executeBatch()方法,这样就可以在一次方法调用中执行多条SQL语句,以提高执行效率。
• 为了保证这一批语句要么全部成功,要么全部失败,应该把批处理放置在事务中进行。
• 使用PreparedStatement也可以进行批处理
简单地说,JDBC可做三件事:与数据库建立连接、发送 SQL 语句并处理结果。
• 对获得Connection对象进行封装
– 将数据库的配置信息写到一个属性文件中,然后用IO流去获取,当需要修改数据库连接的时候只要改动配置文件即可。
– 在src下新建属性文件jdbc.properties,添加如下内容:
• driver=com.mysql.jdbc.Driver
• url=jdbc:mysql://localhost:3306/test
• username=root
• password=root
• 对关闭JDBC资源类的封装
– 新建DbClose.java类,添加方法关闭结果集对象、语句对象、连接对象。
– 在执行增加、删除、修改的时候可以使用代码关闭连接:DbClose.close(Statement stmt, Connection conn);
– 在执行查询之后使用如下代码关闭连接:DbClose.close(ResultSet rs, Statement stmt, Connection conn);
四, 实例
private Connection conn;
private PreparedStatement pstmt;
private ResultSet rs;
/* 操作插入 */
public boolean insert(Student entity) {
/* 第一步:声明返回结果变量 */
boolean flag = false;
try {
/* 第二步:获取连接对象 */
conn = JdbcUtil.getConnection();
/* 第三步:定义sql语句 */
String sql = "insert into student(name,sex,resume,image) values(?,?,?,?)";
/* 第四步:根据sql语句创建预处理对象 */
pstmt = conn.prepareStatement(sql);
/* 第五步:为站位符赋值 */
int index = 1;
pstmt.setObject(index++, entity.getName());
pstmt.setObject(index++, entity.getSex());
pstmt.setObject(index++, entity.getResume());
// pstmt.setBinaryStream(parameterIndex, x)
pstmt.setObject(index++, entity.getImage());
/* 第六步:执行更新 */
int i = pstmt.executeUpdate();
/* 第七步:判断 */
if (i > 0) {
flag = true;
}
/* 第八步:释放资源 */
JdbcUtil.release(rs, pstmt, conn);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
/* *****修改返回变量值 */
return flag;
}。
- Java_09_15课堂总结
- 课堂总结
- 课堂总结
- 课堂总结
- 课堂总结
- 课堂总结
- 课堂总结
- 课堂总结
- Java_09_05课堂总结
- Java_09_06课堂总结
- Java_09_07课堂总结
- Java_09_08课堂总结
- Java_09_13课堂总结
- Java_09_14课堂总结
- Java_09_19课堂总结
- Java_09_20课堂总结
- Java_09_21课堂总结
- Java_09_26_课堂总结
- 观察者模式
- 计算机网络中的七层协议随笔
- Hello World!
- CG大事记
- java容器(一)
- Java_09_15课堂总结
- Java中的多线程:sleep, wait, join 与 interrupt()的关系
- 6.UEFI Shell Users’ Guide
- 给力注册
- CG快报 2011.9.11
- WPF中为ListView动态绑定数据且添加一列复选框
- hdu 4033
- find的用法
- Oracle 工具