[英]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.