java 读取写入 mysql blob

package com.sohu.smc.test;


import java.io.ByteArrayInputStream;

import java.io.ByteArrayOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.Statement;

import java.sql.Connection;

import java.util.zip.GZIPInputStream;

import java.util.zip.GZIPOutputStream;


public class MySqlTest {

static String str = "中国Chinaasdsaiuhdiusankjxnbsiudisabxisaiuaiushxnaiuiusax";


public static String compress(String str) throws IOException {

if (str == null || str.length() == 0) {

return str;

}

ByteArrayOutputStream out = new ByteArrayOutputStream();

GZIPOutputStream gzip = new GZIPOutputStream(out);

gzip.write(str.getBytes());

gzip.close();

return out.toString("ISO-8859-1");

}


public static String uncompress(String str) throws IOException {

if (str == null || str.length() == 0) {

return str;

}

ByteArrayOutputStream out = new ByteArrayOutputStream();

ByteArrayInputStream in = new ByteArrayInputStream(

str.getBytes("ISO-8859-1"));

GZIPInputStream gunzip = new GZIPInputStream(in);

byte[] buffer = new byte[256];

int n;

while ((n = gunzip.read(buffer)) >= 0) {

out.write(buffer, 0, n);

}

// toString()使用平台默认编码,也可以显式的指定如toString("GBK")

return out.toString();

}


static void query() {

Connection conn = null;

try {

Class.forName("com.mysql.jdbc.Driver");

conn = DriverManager.getConnection(

"jdbc:mysql:///", "",

"");

Statement statement = conn.createStatement();

ResultSet rs = statement.executeQuery("select * from test");

while (rs.next()) {

ByteArrayInputStream strtianliang = (ByteArrayInputStream) rs

.getBlob("desc0").getBinaryStream();

byte[] byte_data = new byte[strtianliang.available()];

strtianliang.read(byte_data, 0, byte_data.length);

String result = new String(byte_data);

System.out.println("result uncompress :" + uncompress(result));


}

rs.close();


} catch (Exception e) {

e.printStackTrace();

} finally {

if (conn != null) {

try {

conn.close();

conn = null;

} catch (Exception e) {

e.printStackTrace();

}

}

}

}


static void insert() {

Connection conn = null;

try {

Class.forName("com.mysql.jdbc.Driver");


conn = DriverManager.getConnection(

"");


PreparedStatement st = null;

String str0 = compress(str);

String sql = "insert into test(desc0) values(?)";

st = conn.prepareStatement(sql);

byte[] str0s = str0.getBytes();

InputStream bastr = new ByteArrayInputStream(str0s);

st.setBinaryStream(1, bastr, str0s.length);

st.executeUpdate();

} catch (Exception e) {

e.printStackTrace();

} finally {

if (conn != null) {

try {

conn.close();

conn = null;

} catch (Exception e) {

e.printStackTrace();

}

}

}

}


public static void main(String[] args) throws Exception {

insert();

System.out.println("-----------------------------------");

query();


}

}


转载于:https://my.oschina.net/u/1388024/blog/303815

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值