Хитрость, как этого добиться, описана в этой теме: http://justonjava.blogspot.it/2010/09/lazy-one-to-one-and-one-to-many.html
Я проверил это на Hibernate v.4.3.5 и JPA v.1.5.0, PostgreSQL 9.3. Работал как шарм.
Пример:
public class Attachment implements FieldHandled{
@Transient
private FieldHandler fieldHandler;
...
...
@Lob
@Column(name=CONTENT, nullable=false)
@Basic(fetch = FetchType.LAZY, optional = false)
private byte[] content;
...
...
public byte[] getContent() {
if(fieldHandler!=null){
return (byte[])fieldHandler.readObject(this, "content", content);
}
return content;
}
public void setContent(byte[] content) {
if(fieldHandler!=null){
fieldHandler.writeObject(this, "content", this.content, content);
return;
}
this.content = content;
}
}
Примечание. Если вы используете CGLib, реализуйте net.sf.cglib.transform.impl.InterceptFieldEnabled вместо FieldHandled, используя тот же подход.