JDBC返回生成的主键

思路:
通过一个重载的prepareStatement(sql,int);来设置是否返回由数据库生成的主键
然后再使用ps.getGenereatedKeys()来获得包含主键的结果集

import java.io.FileInputStream;
import java.io.OutputStream;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;

public class ReturnPrimaryKey {

	public static void main(String[] args) throws Exception {	
		write("d:/t.png");
		
	}

	public static void write(String dir)throws Exception{
			String sql="insert into pic values(null,?)";
			try(Connection conn=JdbcUtil.getConnection();
					PreparedStatement ps=conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);){
				//在此处设置是否返回由数据库生成的主键然后用ps.getGeneratedKeys()获得主键的结果集
				
			Blob blob= conn.createBlob();
			OutputStream os=blob.setBinaryStream(1);
			FileInputStream fis=new FileInputStream(dir); 
			
			byte[]bs=new byte[100];
			int size=-1;
			while((size=fis.read(bs))!=-1) {
				os.write(bs,0,size);
			}
			fis.close();
			os.close();			
			ps.setBlob(1, blob);
			ps.execute();
			
			//获得生成的主键
			ResultSet keys=ps.getGeneratedKeys();
			keys.next();
			System.out.println("生成的主键是:"+keys.getInt(1));
			System.out.println("完成");	
			
			}
	}

}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值