PostgreSQL + Hibernate 关于 Bytea 和 oid 的映射问题

本文介绍了在使用Hibernate与PostgreSQL数据库时遇到的Bytea类型映射问题,分析了问题的原因并提供了两种解决方案:一是将字段类型改为byte[],二是自定义PostgreSQLDialect以正确处理Blob类型。这两种方法各有优缺点,选择时需考虑内存管理和移植性。
摘要由CSDN通过智能技术生成

本人博客已经迁移至 www.shangyang.me 欢迎大家访问

 

问题起始,

1. 我在pojo里面定义了一个 binaryData,想通过Blob类型映射,

	public Blob getBinaryData() {
		return _binaryData;
	}

	public void setBinaryData(Blob binaryData) {
		this._binaryData = binaryData;
	}

2. Hibernate 配置文件片段

     <property name="_binaryData" access="field" type="blob" not-null="true">
             <column name="BINARYDATA" not-null="true" />
        </property>

3. Database 对应的Column 为 bytea 

4.Java 代码 

     InputStream stream = getClass().getResourceAsStream("CrissAngel.jpg");
     picStorage1.setBinaryData(Hibernate.createBlob(stream));
		
    _picStorageDAO.save( picStorage1 );		

4. 报错

ERROR JDBCExceptionReporter - ERROR: column "binarydata" is of type bytea but expression is of type bigint
Hint: You will need to rewrite or cast the expression.
Position: 42
27 Jul 2010 17:12:13,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值