Oracle存储图片

Oracle存储图片

Oracle存储图片

  1. 获取图片的流
  2. 先向数据库中存储一个空blob对象
  3. 查询获取空的blob对象
  4. 将图片存储blob对象中
	public void saveImg() throws Exception{
		// 将二进制数据写入Blob
		URL httpUrl=new URL("http://127.0.0.1:8081/TrueTF/imgs/c-icon.png");
		HttpURLConnection conn1=(HttpURLConnection) httpUrl.openConnection();
        //以Post方式提交表单,默认get方式
        conn1.setRequestMethod("GET");
        conn1.setDoInput(true);  
        conn1.setDoOutput(true);
        // post方式不能使用缓存 
        conn1.setUseCaches(false);
        //连接指定的资源 
        conn1.connect();
        //获取网络输入流
        InputStream is=conn1.getInputStream(); 

		
		String sql = "insert into T_TEST_PICTURE(id,pic) values(1,empty_blob())";
		int rt = testService.updateSQL(sql);
		if( rt > 0){
			System.out.println("initialization succeed!!");
			String preCursor = "select id,pic from T_TEST_PICTURE where id='1' for update";
			List<Map<String,Object>> maps = testService.findSQL(preCursor);
			Blob b = (Blob)maps.get(0).get("PIC");
			BufferedOutputStream bos = new BufferedOutputStream(b.setBinaryStream(0L));
			BufferedInputStream bis = new BufferedInputStream(is);
			int bytes;
			try {
				while((bytes = bis.read()) != -1){
					bos.write(bytes);
				}
				bis.close();
				bos.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值