Problém je v tom, že váš sloupec s názvem „klíč“ je rezervní slovo v SQL. Obklopte to zpětnými tahy a věci by měly fungovat. Ještě lépe zvažte přejmenování sloupce na něco, co není rezervní slovo SQL. Dokázal jsem to pomocí níže uvedeného kódu:
Tabulka MySQL:
create table keytable (name varchar(255) not null, `key` blob not null);
Java kód:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class MySQLBlobInsert {
public static void main(String[] args) {
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
} catch (Exception e) {
throw new RuntimeException(e);
}
Connection conn = null;
try {
conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password");
byte[] bkey = "This is some binary stuff".getBytes();
String query = "INSERT INTO keytable (name, `key`) VALUES (?,?)";
PreparedStatement pstmt = conn.prepareStatement(query);
pstmt.setString(1, "test");
pstmt.setBytes(2, bkey);
pstmt.execute();
} catch (SQLException e) {
throw new RuntimeException(e);
} finally {
if (conn != null) {
try { conn.close(); } catch (SQLException e) {}
}
}
System.out.println("done :)");
}
}