这是我上一个问题的更深层次的挖掘。
我有一个由Postgresql从NetBeans生成的实体类。源代码是:
package com.longz.ozssc.domain;
import javax.persistence.*;
import java.sql.Time;
import java.util.Arrays;
/**
 * Created by cidylong on 12/01/2015.
*/
@Entity
@Table(name = "file", schema = "public", catalog = "ozssc")
public class FileEntity {
    private String fileId;
    private String referId;
    private String fileName;
    private String fileType;
    private byte[] fileData;
    private Time createdDatatime;
@Id
@Column(name = "file_id", nullable = false, insertable = true, updatable = true, length = 2147483647)
public String getFileId() {
    return fileId;
}
public void setFileId(String fileId) {
    this.fileId = fileId;
}
@Basic
@Column(name = "refer_id", nullable = false, insertable = true, updatable = true, length = 2147483647)
public String getReferId() {
    return referId;
}
public void setReferId(String referId) {
    this.referId = referId;
}
@Basic
@Column(name = "file_name", nullable = false, insertable = true, updatable = true, length = 2147483647)
public String getFileName() {
    return fileName;
}
public void setFileName(String fileName) {
    this.fileName = fileName;
}
@Basic
@Column(name = "file_type", nullable = true, insertable = true, updatable = true, length = 2147483647)
public String getFileType() {
    return fileType;
}
public void setFileType(String fileType) {
    this.fileType = fileType;
}
@Basic
@Column(name = "file_data", nullable = false, insertable = true, updatable = true)
public byte[] getFileData() {
    return fileData;
}
public void setFileData(byte[] fileData) {
    this.fileData = fileData;
}
@Basic
@Column(name = "created_datatime", nullable = false, insertable = true, updatable = true)
public Time getCreatedDatatime() {
    return createdDatatime;
}
public void setCreatedDatatime(Time createdDatatime) {
    this.createdDatatime = createdDatatime;
}
@Override
public boolean equals(Object o) {
    if (this == o) return true;
    if (o == null || getClass() != o.getClass()) return false;
    FileEntity that = (FileEntity) o;
    if (createdDatatime != null ? !createdDatatime.equals(that.createdDatatime) : that.createdDatatime != null)
        return false;
    if (!Arrays.equals(fileData, that.fileData)) return false;
    if (fileId != null ? !fileId.equals(that.fileId) : that.fileId != null) return false;
    if (fileName != null ? !fileName.equals(that.fileName) : that.fileName != null) return false;
    if (fileType != null ? !fileType.equals(that.fileType) : that.fileType != null) return false;
    if (referId != null ? !referId.equals(that.referId) : that.referId != null) return false;
    return true;
}
@Override
public int hashCode() {
    int result = fileId != null ? fileId.hashCode() : 0;
    result = 31 * result + (referId != null ? referId.hashCode() : 0);
    result = 31 * result + (fileName != null ? fileName.hashCode() : 0);
    result = 31 * result + (fileType != null ? fileType.hashCode() : 0);
    result = 31 * result + (fileData != null ? Arrays.hashCode(fileData) : 0);
    result = 31 * result + (createdDatatime != null ? createdDatatime.hashCode() : 0);
    return result;
}
@Override
public String toString() {
    return "com.longz.ozssc.model.FileEntity[ fileId=" + fileId + " ]";
}
}这是我在我们的项目中使用的非常流行的实体类。实体的主键是fileId,有一组getter/setter对来访问实体中的这个私有属性,比如setFileId(String fileId)和getFileId()。
我的远程接口是:
/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.longz.ozssc.remote;
import com.longz.ozssc.model.FileEntity;
import java.util.List;
import javax.ejb.Remote;
/**
 *
 * @author cidylong
*/
@Remote
public interface FileEntityFacadeRemote {
  void create(FileEntity fileEntity);
  void edit(FileEntity fileEntity);
  void remove(FileEntity fileEntity);
  FileEntity find(Object id);
  List<FileEntity> findAll();
  List<FileEntity> findRange(int[] range);
  int count();
}我的EJB实现是:
/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.longz.ozssc.ejb;
import com.longz.ozssc.model.FileEntity;
import com.longz.ozssc.remote.FileEntityFacadeRemote;
import com.longz.ozssc.remote.OzsscIdSequenceFacadeRemote;
import com.longz.ozssc.utils.datatime.DateTimeAssistant;
import java.text.ParseException;
import java.util.Calendar;
import java.util.Date;
import java.util.LinkedList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.ejb.EJB;
import javax.ejb.Remote;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;
import org.apache.commons.lang3.StringUtils;
/**
 *
 * @author cidylong
 */
@Remote(FileEntityFacadeRemote.class)
@Stateless(mappedName="fileEntityFacadeEJB")
public class FileEntityFacade extends AbstractFacade<FileEntity> implements FileEntityFacadeRemote {
    @PersistenceContext(unitName = "OzsscJPANBPU")
    private EntityManager em;
  @Override
  protected EntityManager getEntityManager() {
    return em;
}
  public FileEntityFacade() {
    super(FileEntity.class);
}
  @EJB
  private OzsscIdSequenceFacadeRemote ozsscIdSqFaRemote;
  @Override
  public List<FileEntity> findAll(){
    Query query = em.createNamedQuery("FileEntity.findAllOrderByCreated");
    return new LinkedList<FileEntity>(query.getResultList());
    /*return super.findAll();*/
}
}每次调用实体方法getFileId()时,
 String fileId = (FileEntity)fileEntity.getFileId();假设我将从实体获得一个字符串返回,如下所示:
**FILES20150200013**. 但我的实体总是会回来:
**com.longz.ozssc.model.FileEntity[ fileId= FILES20150200013 ]**这个返回值正是其他实体方法toString()的输出。
当我调用getFileId()方法访问实体的主键时,该实体将整个实体值返回给我,而不是返回一个主键。
我的代码中有什么问题或者实体访问方法中有什么错误吗?
任何建议都是受欢迎的,并且非常感谢。
编辑:
当我试图使用JPA2.0提供的方法访问实体的主键时:
Object identifier = 
                EntityManagerFactory.getPersistenceUnitUtil().getIdentifier(fileEntity);我也得到了错误的回报。烦人??
发布于 2015-03-01 04:04:28
我自己发现了这个问题。
事实上。我用java客户端(包括WebLogic客户端库)测试它,发现它在Java中工作得很好。
然后,我将相同的测试代码放在Spring上下文中,而不是工作。Spring控制器总是给出错误的返回值。这很有趣。
作为另一种解决办法。我使用Spring对象代替FirmEntity使用ABN字符串重新组织参数,然后将ABN字符串传递给EJB,得到正确的返回。
这也许可以帮助其他遇到同样问题的人。我认为这个问题是由Spring框架的AOP特性引起的,谁绑定了错误的字符串来返回值,在使用这些特性时应该非常小心。
https://stackoverflow.com/questions/28788092
复制相似问题