java 写入mysql blob_java 读取写入 mysql blob

2019独角兽企业重金招聘Python工程师标准>>>

6936d1565ae689371725cdb5fc51c415.png

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();

}

}

`MYSQL_STMT` 是 MySQL 驱动程序中用于执行预编译语句(PreparedStatement)的功能,它提供了一种更高效、安全的方式来操作数据库,尤其是在处理大数据类型如 `BLOB`(二进制大对象)时。 当你想要将数据写入 `BLOB` 列时,可以通过 `MYSQL_STMT` 对象的操作方法来实现。以下是一个基本步骤: 1. **准备语句**: 使用 `stmt_prepare()` 函数创建一个预编译的 SQL 语句,比如 `INSERT INTO table_name (blob_column) VALUES (?)`,其中的问号 (`?`) 是占位符,表示后续要插的实际值。 2. **绑定参数**: 使用 `stmt_bind_param()` 函数将参数绑定到占位符上。对于 `BLOB` 类型的参数,你需要指定类型为 `MYSQL_TYPE_BLOB`。例如: ```sql stmt_bind_param(stmt, "s", blob_value); // s 表示第二个参数位置,blob_value 是 BLOB 数据 ``` 3. **设置 Blob 参数**: 如果 `blob_value` 是内存中的数据,你可以直接用 `blob_value`;如果是文件路径或流,可能需要用 `LOAD_FILE()` 函数读取: ```sql stmt_bind_param(stmt, "s", LOAD_FILE('/path/to/your/file')); ``` 4. **执行语句**: 执行准备好的语句使用 `stmt_execute()` 函数。 5. **获取结果影响行数**: 如果关心是否有影响到数据库,可以使用 `stmt_affected_rows()` 获取受影响的行数。 6. **关闭资源**: 在完成所有操作后,记得关闭 `MYSQL_STMT` 和连接资源,使用 `stmt_close()` 和 `mysql_free_result()`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值