繁体   English   中英

如何将Java中的字节存储到PostgreSQL中的bytea中?

[英]How to store byte from Java into a bytea in PostgreSQL?

当我尝试将Java中“字节”类型的变量插入PostgreSQL中“字节”类型的变量时遇到问题。

这是我在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模式),因此我需要通过端口串行发送字节值。 因此,我只是在验证从数据库中获取的值是否与我在其中插入的值相同。 总之,我想知道如何从数据库中恢复字节以通过串行端口发送它们。

PostgreSQL编写Java代码

pst.setBinaryStream(6, mesa.getSom());
pst.setBinaryStream(7, mesa.getRotina());
pst.setBinaryStream(8, mesa.getAddress64Bits());`

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM