【转】JDBC学习笔记(6)——获取自动生成的主键值&处理Blob&数据库事务处理
转自:http://www.cnblogs.com/ysw-go/
获取数据库自动生成的主键
我们这里只是为了了解具体的实现步骤:我们在插入数据的时候,经常会需要获取我们插入的这一行数据对应的主键值。
具体的代码实现:

1 /**
2 * 获取数据库自动生成的主键
3 */
4 @Test
5 public void testGetKeyValues(){
6 Connection connection=null;
7 PreparedStatement preparedStatement=null;
8 ResultSet rs=null;
9 try {
10 connection=JDBCTools.getConnection();
11 String sql="insert into customers(name,email,birth)"+
12 " values(?,?,?)";
13 // preparedStatement=connection.prepareStatement(sql);
14 //我们这里使用重载的prepareStatement(sql,flag)方法
15 //来生成prepareStatement对象
16 preparedStatement=connection.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
17 preparedStatement.setString(1, "ABCDE");
18 preparedStatement.setString(2, "abcd@guigu.com");
19 preparedStatement.setDate(3, new Date(new java.util.Date().getTime()));
20 preparedStatement.executeUpdate();
21 //通过getGeneratedKeys方法获取包含了新生成的主键的ResultSet对象
22 //在ResultSet结果集中,只包含一列,列名:GENERATED_KEY,用于存放新生成的主键值
23 rs=preparedStatement.getGeneratedKeys();
24 if(rs.next()){
25 System.out.println(rs.getObject(1));
26 }
27 ResultSetMetaData rsmd=rs.getMetaData();
28 for(int i=0;i<rsmd.getColumnCount();i++){
29 System.out.println(rsmd.getColumnName(i+1));
30 }
31 } catch (Exception e) {
32 e.printStackTrace();
33 }finally{
34 JDBCTools.release(rs,preparedStatement,connection);
35 }
36 }

处理Blob
Blob的基本概念


1).插入Blob类型数据

/**
* 插入Blob类型的数据必须使用PreparedStatement
* 因为Blob类型的数据是无法使用字符串拼写的
*
* 调用setBlob(int index,InputStream,inputStream)
*/

具体代码实现:

1 @Test
2 public void testInsertBlod(){
3 Connection connection=null;
4 PreparedStatement preparedStatement=null;
5 ResultSet rs=null;
6 try {
7 connection=JDBCTools.getConnection();
8 String sql="insert into customers(name,email,birth,picture)"+
9 " values(?,?,?,?)";
10 // preparedStatement=connection.prepareStatement(sql);
11 //我们这里使用重载的prepareStatement(sql,flag)方法
12 //来生成prepareStatement对象
13 preparedStatement=connection.prepareStatement(sql);
14 preparedStatement.setString(1, "ABCDE");
15 preparedStatement.setString(2, "abcd@guigu.com");
16 preparedStatement.setDate(3, new Date(new java.util.Date().getTime()));
17 InputStream inputStream=new FileInputStream("blob.png");
18 preparedStatement.setObject(4, inputStream);
19 preparedStatement.executeUpdate();
20
21 } catch (Exception e) {
22 e.printStackTrace();
23 }finally{
24 JDBCTools.release(rs,preparedStatement,connection);
25 }
26 }

2).读取Blob类型数据
/**
* 读取Blob数据:
* 1.使用getBlob方法,读取Blod对象
* 2.调用Blob的getBinaryStream()方法得到输入流,再使用IO操作即可
*/
具体代码实现:

1 @Test
2 public void testReadBlob(){
3 Connection connection = null;
4 PreparedStatement preparedStatement = null;
5 ResultSet resultSet = null;
6 try {
7 connection = JDBCTools.getConnection();
8 String sql = "select id,name,email,birth,picture"+
9 " from customers where id =18";
10 preparedStatement = connection.prepareStatement(sql);
11 resultSet = preparedStatement.executeQuery();
12 if (resultSet.next()) {
13 int id=resultSet.getInt(1);
14 String name=resultSet.getString(2);
15 String email=resultSet.getString(3);
16 System.out.println(id+":"+name+":"+email);
17 Blob pictureBlob=resultSet.getBlob(5);
18 InputStream inputStream=pictureBlob.getBinaryStream();
19 OutputStream out=new FileOutputStream("flo.png");
20 byte[] buffer=new byte[1024];
21 int len =0;
22 while((len=inputStream.read(buffer))!=-1){
23 out.write(buffer,0,len);
24 }
25 out.close();
26 inputStream.close();
27 }
28 } catch (Exception e) {
29 e.printStackTrace();
30 } finally {
31 JDBCTools.release(resultSet, preparedStatement, connection);
32 }
33 }

数据库事务
数据库事务概述

数据库事务的四个属性

JDBC的数据库事务

我们做一个小实验:
先建立一个数据表:

试验中要用到的更新数据的通用方法update():

1 public static void update(Connection connection,String sql,
2 Object ...args){
3 /**
4 * 执行SQL语句,使用PreparedStatement
5 */
6 PreparedStatement preparedStatement=null;
7 try {
8 preparedStatement=connection.prepareStatement(sql);
9 for(int i=0;i<args.length;i++){
10 preparedStatement.setObject(i+1, args[i]);
11 }
12 preparedStatement.executeUpdate();
13 } catch (Exception e) {
14 e.printStackTrace();
15 }finally{
16 JDBCTools.release(null, preparedStatement, null);
17 }

我们要完成的是:Tom->Jerry汇款500元
* 数据库事务
* 关于事务:
* 1.如果多个操作,每个操作使用的是自己的单独的连接,则无法保证事务
* 2.具体步骤:
* 1).开始事务,取消默认自动提交行为
* 2).如果事务的操作都成功,则提交事务:connection.commit();
* 3).回滚事务:若出现异常,则在catch块中回滚事务
我们组织代码就按照上面的步骤来进行.

1 public void testTeansaction() throws Exception{
2 Connection connection=null;
3 try {
4 connection=JDBCTools.getConnection();
5 System.out.println(connection.getAutoCommit());
6 String sql="update users set balance=balance-500 where id=1";
7 //开始事务:取消默认提交
8 connection.setAutoCommit(false);
9 update(connection,sql);
10 int i=10/0;
11 System.out.println(i);
12 sql="update users set balance=balance+500 where id=2";
13 JDBCTools.update(sql);
14 //提交事务
15 connection.commit();
16 } catch (Exception e) {
17 e.printStackTrace();
18 //回滚事务
19 try {
20 connection.rollback();
21 } catch (SQLException e1) {
22 e1.printStackTrace();
23 }
24 }finally{
25 //关闭连接
26 JDBCTools.release(null, null, connection);
27 }
28 }

可以发现,因为我们使用的是同一个connection连接,当异常(除数为0)发生的时候,事务会发生回滚,数据库的数据会恢复到事务开始之前的状态.
【转】JDBC学习笔记(6)——获取自动生成的主键值&处理Blob&数据库事务处理的更多相关文章
- JDBC学习笔记(6)——获取自动生成的主键值&处理Blob&数据库事务处理
获取数据库自动生成的主键 [孤立的技术是没有价值的],我们这里只是为了了解具体的实现步骤:我们在插入数据的时候,经常会需要获取我们插入的这一行数据对应的主键值. 具体的代码实现: /** * 获取数据 ...
- JDBC 获取自动生成的主键
为什么需要获取自动生成的主键 例如:
- Java -- JDBC 获取数据库自动 生成的主键值
public class Demo4 { /* create table test1 ( id int primary key auto_increment, name varchar(20) ); ...
- MYSQL 之 JDBC(十一): JDBC获取插入记录的主键值
取得数据库自动生成的主键值 package com.litian.jdbc; import javax.swing.plaf.nimbus.State; import java.sql.*; /** ...
- (jdbc)取得数据库自动生成的主键方法
一些类,在前面的博客中有,就不重复了 public class Test2 { TestDAO t=new TestDAO(); /*前提是数据表的主键是自动增加的, *取得数据库自动生成的主键 * ...
- javaweb学习总结(三十七)——获得MySQL数据库自动生成的主键
测试脚本如下: 1 create table test1 2 ( 3 id int primary key auto_increment, 4 name varchar(20) 5 ); 测试代码: ...
- Java_jdbc 基础笔记之十五 数据库连接(取得数据库自动生成的主键)
public class testGetKeyValue { /** * 取得数据库自动生成的主键 */ @Test public void testGeneratedKeys() { Connect ...
- 五.获得MYSQL数据库自动生成的主键
测试脚本如下: 1 create table test1 2 ( 3 id int primary key auto_increment, 4 name varchar(20) 5 ); 测试代码: ...
- javaweb(三十七)——获得MySQL数据库自动生成的主键
测试脚本如下: 1 create table test1 2 ( 3 id int primary key auto_increment, 4 name varchar(20) 5 ); 测试代码: ...
随机推荐
- java 使用Stack来判断Valid Parentheses
假如定义形如"{}[]()"或者"{[()]}"的模式为valid,"[{]"或者"(("的模式为invalid,那么我 ...
- WeMall微商城源码投票插件Vote的主要源码
WeMall微信商城源码投票插件Vote,用于商城的签到系统,分享了部分比较重要的代码,供技术员学习参考 AdminController.class.php <?php namespace Ad ...
- 1644: [Usaco2007 Oct]Obstacle Course 障碍训练课
1644: [Usaco2007 Oct]Obstacle Course 障碍训练课 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 383 Solved ...
- 通过git提交代码到仓库
昨天有一个妹子问我如何在还没有commit之前push本地的代码到仓库,现在写写,希望能够帮到大家. 当我们pull的时候会出现没有代码commit的错误提示,在这种情况下,我们需要再commit之前 ...
- Node软件的安装
1.官网网址:https://nodejs.org/en/ 左边被推荐,右边最新 下载完成一键下一步直接安装,当然,如果你想修改安装目录的话当然没问题,注意:不要有英文目录 2.Window+r打开命 ...
- 小命令tac、cat、rev的用法
cat:输出文件的内容(正序,由上至下) tac:输出文件的内容(倒序,由下至上) rev: 反转每行的文字内容,行号不变 示例:建立一个文件夹 1.演示cat效果 按原始样式正常显示 2.演示tac ...
- JAVA基础知识(1)
1.JAVA的三大体系:JME(微缩版),JSE(标准版),JEE(企业版): 2.JAVA的三大核心机制:JAVA虚拟机,垃圾回收机制,代码安全性检测 3.java开发集JDK 4.java编译器j ...
- 【树莓派】Linux 测网速及树莓派源
这篇文章比较杂,其中包含三点:linux环境中测试网络速度,树莓派下载软件的源,部分我写好的脚本: 一.Linux 测网速 Linux 测网速: sar -n DEV 1 100 1代表一秒统计并显示 ...
- Seajs使用实例入门介绍
本文所用例子的代码目录结构: seajs example |--sea-module //存在依赖文件 |--jquery |--jqeury.js |--sea.js |--static //存放自 ...
- sql 两种分页offset和row_number简单分析
新建临时表字段id,向临时表里插入1,2,3,4,5,6 if object_id('tempdb..#test') is not null drop table #test create table ...