当我尝试将 Java 中的“byte”类型的变量插入 PostgreSQL 中的“bytea”类型的变量时,我遇到了问题。
这是我在 postgresql 中的表:
CREATE TABLE mesa (
id_mesa serial PRIMARY KEY,
tag varchar(50),
modelo varchar(50),
menor_complemento smallint NOT NULL,
peso_min smallint NOT NULL,
peso_max smallint NOT NULL,
som bytea NOT NULL,
rotina bytea NOT NULL,
address64bits bytea NOT NULL UNIQUE
);
我的Java代码如下:
private Mesa mesa;
//construtor
public MesaDAO (Mesa mesa) {
this.mesa = mesa;
}
(...)
String stm = "INSERT INTO mesa(tag, modelo, menor_complemento, peso_min, "
+ "peso_max, som, rotina, address64bits) "
+ "VALUES(?,?,?,?,?,?,?,?)";
try {
pst = con.prepareStatement(stm);
pst.setString(1, mesa.getTag());
pst.setString(2, mesa.getModelo());
pst.setInt(3, mesa.getMenorComplemento());
pst.setInt(4, mesa.getPesoMin());
pst.setInt(5, mesa.getPesoMax());
pst.setByte(6, mesa.getSom());
pst.setByte(7, mesa.getRotina());
pst.setBytes(8, mesa.getAddress64Bits());
pst.executeUpdate();
(...)
台面类型有:
public class Mesa{
private Integer idMesa;
private String tag;
private String modelo;
private Integer menorComplemento;
private Integer pesoMin;
private Integer pesoMax;
private byte som;
private byte rotina;
private byte[] address64Bits;
(...)
}
然后,当我尝试插入一些东西时,它会抛出一个 PSQLException ,指出列 "som" 是 "bytea" 但表达式是 "smallint"。我还认为它会在那之后的以下两行中具有相同的 SQLException。
所以我不知道如何解决这个问题,如果有人可以帮助我,我会很高兴!
先感谢您,
编辑:
感谢大家帮助我,我将在这里提供解决方案:将变量“som”和“rotina”更改为“byte[]”类型,然后使用 pst.getBytes(...) 而不是 pst.getByte(... )。
澄清:
我正在使用 XBee(API 模式),所以我需要通过端口串行发送字节值。所以我只是在验证我从数据库中获得的值是否与我插入的那个值相同。总之,我想知道如何从数据库中恢复字节以通过串口发送它们。