JDBC读取数据库图片

 

	/**
	 * 更新BLOB字段
	 * 
	 * @param tableCode
	 * @param fieldCode
	 * @param fieldValue
	 * @param primaryKey
	 * @param primaryValue
	 * @return
	 * @throws DAOException
	 */
	public int updateBlob(String tableCode, String fieldCode,
			byte[] fieldValue, String primaryKey, String primaryValue)
			throws DAOException {
		String sql = "UPDATE ##TABLECODE## SET ##FIELDCODE## =? WHERE ##PRIMARYKEY## = ##PRIMARYVALUE##";
		sql = StringUtil.replaceAllString/*AllString*/(sql, "##TABLECODE##",
				tableCode);
		sql = StringUtil.replaceAllString/*AllString*/(sql, "##PRIMARYKEY##",
				primaryKey);
		sql = StringUtil.replaceAllString/*AllString*/(sql,
				"##PRIMARYVALUE##", "'"+primaryValue+"'");
		sql = StringUtil.replaceAllString/*AllString*/(sql, "##FIELDCODE##",
				fieldCode);
		SQLParameter param = new SQLParameter();
		param.addBlobParam(fieldValue);
		return getBaseDAO().executeUpdate(sql, param);
	}
 

 

 

        public static void main(String[] args) throws Exception {
                Class.forName("oracle.jdbc.driver.OracleDriver");
                Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl", "ymd", "1");
                Statement statement = conn.createStatement();
                StringBuffer sql = new StringBuffer("")
                .append(" select a.psnname, ") 
                .append("        a.photo, ") 
                .append("        to_number(to_char(sysdate, 'YYYY')) - ") 
                .append("        to_number(substr(a.birthdate, 1, 4)) age, ") 
                .append("        b.docname ") 
                .append("   from bd_psnbasdoc a ") 
                .append("   left join bd_defdoc b on a.marital = b.pk_defdoc ") 
                .append("  where a.sex = '女' ") 
                .append("    and a.photo is not null "); 

                ResultSet resultSet = statement.executeQuery(sql.toString());
                while(resultSet.next()){
                        Blob blob = resultSet.getBlob("photo");
                        String name = resultSet.getString("psnname");
                        String age = resultSet.getString("age");
                        String docname = resultSet.getString("docname") == null ? " " : resultSet.getString("docname");
                        InputStream inputStream = blob.getBinaryStream();
                        
                        OutputStream outputStream = new FileOutputStream(new File("c:\\PIC\\"+name+"_"+age+"_"+docname+".jpg"));
                        
                byte[] buffer = new byte[1204];

                int bytesum = 0;
                int byteread = 0;
                while ((byteread = inputStream.read(buffer)) != -1) {
                    bytesum += byteread;
                    outputStream.write(buffer, 0, byteread);
                }
                outputStream.flush();
                outputStream.close();
                        inputStream.close();
                }
                
                statement.close();
                conn.close();
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值