mysql 存byte数组中_byte数组存储到mysql

public int AddVeinMessage(byte[] data)//插入数据库

{

using (BCSSqlConnection = new MySqlConnection(strConn))

{

try

{

dbHelper = new DBHelper(BCSSqlConnection);

StringBuilder sbSql = new StringBuilder();

sbSql.Append("insert into table1(");

sbSql.Append("data)");

sbSql.Append(" values (");

sbSql.Append(" ?data)");

string strInsertSql = sbSql.ToString();

MySqlCommand cmd = dbHelper.GetSqlStringCommond(strInsertSql);

dbHelper.AddInParameter(cmd, "?data", MySqlDbType.VarBinary, FINGERDATA);

return dbHelper.ExecuteNonQuery(cmd);

}

catch (Exception ex)

{

System.Windows.Forms.MessageBox.Show("添加失败了" + ex.Message);

return 0; //表示数据库异常

}

finally

{

dbHelper.CloseSqlConnection(); //关闭数据库

}

}

}

从数据库中取出

public DataTable SelectVeinMessage()

{

using (BCSSqlConnection = new MySqlConnection(strConn))

{

try

{

StringBuilder sbSql = new StringBuilder();

sbSql.Append("select data from table");

//设置MYSQL查询语句用于查询符合查询条件的记录

string strSql = sbSql.ToString();

dbHelper = new DBHelper(BCSSqlConnection);

//调用DBHelper类中的GetSqlStringCommond()方法将返回的MySqlCommand对象赋给cmd

MySqlCommand cmd = dbHelper.GetSqlStringCommond(strSql);

// dbHelper.AddInParameter(cmd, "?FINGERDATA", MySqlDbType.VarChar, FINGERDATA);

//调用DBHelper类的ExecuteDataSet()方法

DataTable dt = dbHelper.ExecuteDataTable(cmd);

//返回DataTable对象dt

return dt;

}

catch (Exception e)

{

throw new Exception(e.Message);

}

finally

{

dbHelper.CloseSqlConnection();

}

}

}

DataTable dt = mm.SelectVeinMessage1();

byte[] TemplateBuff = new byte[512];

for (int i = 0; i < dt.Rows.Count; i++)

{

TemplateBuff = (byte[])dt.Rows[i]["data"];

}

### 回答1: 在 Java 中可以使用 ByteArrayInputStream 类将 byte 数组转换成二进制对象。例如: ``` byte[] byteArray = ...; ByteArrayInputStream bais = new ByteArrayInputStream(byteArray); ObjectInputStream ois = new ObjectInputStream(bais); Object object = ois.readObject(); ``` 上面的代码将 byte 数组转换成 ByteArrayInputStream 对象,再使用 ObjectInputStream 从输入流中读取对象,最后将对象赋值给 object。 您需要确保被转换成二进制对象的类实现了 Serializable 接口 ### 回答2: 在Java中,将byte数组转化为二进制大对象(BLOB)需要依赖数据库操作。下面是一个使用JDBC API的示例代码: ``` import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class ByteToBlobExample { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/database_name?useSSL=false"; // 数据库连接URL String username = "username"; // 数据库用户名 String password = "password"; // 数据库密码 byte[] byteArray = { 0x01, 0x02, 0x03, 0x04, 0x05 }; // 待转换的byte数组 try (Connection connection = DriverManager.getConnection(url, username, password)) { String sql = "INSERT INTO table_name (blob_column) VALUES (?)"; // 表和列名需替换为实际使用的 PreparedStatement statement = connection.prepareStatement(sql); statement.setBytes(1, byteArray); // 将byte数组设置为BLOB参数的值 statement.executeUpdate(); System.out.println("Byte array has been converted and inserted into BLOB column successfully."); } catch (SQLException e) { System.out.println("Error occurred while converting byte array to BLOB: " + e.getMessage()); } } } ``` 上述代码会将byte数组转换为二进制大对象并插入数据库中的相应表和列中。请确保替换示例代码中的数据库连接URL、用户名、密码以及表和列名为实际使用的值。 ### 回答3: 在Java中,将byte数组转换为二进制大对象可以通过使用输入输出流和文件操作来实现。 首先,创建一个字节输入流对象,并将byte数组作为输入源。然后,创建一个二进制大对象输出流对象,并指定将数据写入到一个文件中。 接下来,通过迭代读取byte数组中的数据,使用二进制大对象输出流的write方法将数据写入文件。代码如下: ```java import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; public class ByteToBlob { public static void main(String[] args) { byte[] byteArr = {1, 2, 3, 4, 5}; // 假设有一个byte数组 try { // 创建字节输入流对象 FileInputStream fis = new FileInputStream("input.txt"); // 创建二进制大对象输出流对象 FileOutputStream fos = new FileOutputStream("output.blob"); // 迭代读取byte数组中的数据,写入到文件 for (byte b : byteArr) { fos.write(b); } // 关闭输入输出流 fis.close(); fos.close(); System.out.println("Byte array has been converted to binary large object."); } catch (IOException e) { e.printStackTrace(); } } } ``` 以上代码中,首先创建一个`FileInputStream`对象,它将从byte数组中读取数据。然后创建一个`FileOutputStream`对象,它用于将数据写入到一个二进制大对象文件中。在迭代byte数组的过程中,通过二进制大对象输出流的write方法将数据写入到文件中。 最后,关闭输入输出流,完成将byte数组转换为二进制大对象的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值