微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

hibernate – Spring,Blob下载,byte []大小增加两倍

我使用Spring 3.0与Hibernate和Postgresql,我有以下问题:
我正在将文件上传数据库,保存其内容类型,一切正常,数据库中字段的大小正常.但是当我尝试下载它时,Hibernate会返回两倍大小的字节数组.下载的文件当然已损坏.大小比数据库中的大小大两倍……我的代码如下:
字段域类(带映射):

private byte[] cv;

@Column(name="cv")
public byte[] getCv() {
  return this.cv;
}

加载对象的DAO函数

public Candidate load(Integer id) {
  return (Candidate) getHibernateTemplate().get(Candidate.class,id);
}

会话工厂配置:

factorybean">

    sqlDialectsql">true

sql创建:

CREATE TABLE candidate
(
  id serial NOT NULL,cv bytea,...
)

如果它有任何不同,数据库将被编码为UTF-8.
我正在尝试使用org.springframework.jdbc.support.lob.DefaultLobHandler,但它没有做到这一点..任何想法?这让我疯狂..

最佳答案
找到解决方案,更改bytea输出数据库设置,如下所示:

ALTER DATABASE SET bytea_output =’escape’;

奥斯卡.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐