1

SelectOneMenu からエンティティのインスタンスを取得したいので、エンティティ変数を他のメソッドに割り当てることができます。しかし、それはnullを指しています。

xhtml コード

<h:selectOneMenu value="#{statusReport.projectDetID}" converter="ObjectStringConv" onchange="#{statusReport.retrieveReport()}" >
                <f:selectItems value="#{statusReport.listOfProjectDetail}"
                    var="projectDetail" itemLabel="#{projectDetail.project}              #{projectDetail.startDate}   -    #{projectDetail.endDate}"
                    itemValue="#{projectDetail}" noSelectionValue="Select the Saved Project"/>
            </h:selectOneMenu>

statusReport Bean

public class StatusReport implements Serializable {


    private ProjectDetail projectDetID;

    private List<ProjectDetail> listOfProjectDetail;

    public List<ProjectDetail> getListOfProjectDetail() {
        listOfProjectDetail = projectDetailFacade.findAll();
        return listOfProjectDetail;
    }

    public void setListOfProjectDetail(List<ProjectDetail> listOfProjectDetail) {
        this.listOfProjectDetail = listOfProjectDetail;
    }
    public ProjectDetail getProjectDetID() {
        return projectDetID;
    }

    public void setProjectDetID(ProjectDetail projectDetID) {
        this.projectDetID = projectDetID;
    }


    public void retrieveReport(){

        System.out.println(" Processing .....");
        if ( projectDetID == null )
        {
            System.out.println("The object from Select null");
        }
        else
        {
        System.out.println("The object from Select menu" + projectDetID.toString());
        }

        System.out.println("Generated Data:Completed");

}}

ProjectDetail エンティティ Bean

package com.jira.entity;

import java.io.Serializable;
import javax.persistence.*;

import java.util.Date;
import java.util.List;


/**
 * The persistent class for the PROJECT_DETAIL database table.
 * 
 */
@Entity
@Table(name="PROJECT_DETAIL",schema="weeklyrep")

public class ProjectDetail implements Serializable {
    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="projectdetail_seq")
    @SequenceGenerator(name="projectdetail_seq",schema="weeklyrep",sequenceName="projectdetail_seq", allocationSize=1)
    @Column(name="PDETAIL_ID")
    private long pdetailId;

    private Boolean completed;

    @Temporal( TemporalType.DATE)
    @Column(name="END_DATE")
    private Date endDate;

    private Long project;

    @Temporal( TemporalType.DATE)
    @Column(name="START_DATE")
    private Date startDate;

    //bi-directional many-to-one association to MajorEvent
    @OneToMany(mappedBy="projectDetail",cascade=CascadeType.ALL)
    private List<MajorEvent> majorEvents;
    //bi-directional one-to-one association to ExecSummary
    @OneToOne(mappedBy="projectDetailExec",cascade=CascadeType.ALL)
    private ExecSummary execSummary;
    public ProjectDetail() {
    }

    public long getPdetailId() {
        return this.pdetailId;
    }

    public void setPdetailId(Long pdetailId) {
        this.pdetailId = pdetailId;
    }

    public Boolean getCompleted() {
        return this.completed;
    }

    public void setCompleted(Boolean completed) {
        this.completed = completed;
    }

    public Date getEndDate() {
        return this.endDate;
    }

    public void setEndDate(Date endDate) {
        this.endDate = endDate;
    }

    public long getProject() {
        return this.project;
    }

    public void setProject(long project) {
        this.project = project;
    }

    public Date getStartDate() {
        return this.startDate;
    }

    public void setStartDate(Date startDate) {
        this.startDate = startDate;
    }

    public List<MajorEvent> getMajorEvents() {
        return this.majorEvents;
    }

    public void setMajorEvents(List<MajorEvent> majorEvents) {
        this.majorEvents = majorEvents;
    }

    public ExecSummary getExecSummary() {
        return execSummary;
    }

    public void setExecSummary(ExecSummary execSummary) {
        this.execSummary = execSummary;
    }


}

コンバータ

コンバーターが必要かどうかはわかりませんが、どのようにコーディングするかはわかりません。

package com.weeklyreport.converters;

import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.convert.Converter;
import javax.faces.convert.FacesConverter;

import com.jira.entity.ProjectDetail;


@FacesConverter(value="ObjectStringConv")
public class ObjectStringConv implements Converter {

    @Override
    public Object getAsObject(FacesContext context, UIComponent component, String svalue) {
        System.out.print("String version of object is:" + svalue);
        return "test";
    }

    @Override
    public String getAsString(FacesContext context, UIComponent component, Object ovalue) {

            return ovalue.toString();
        }

    }

これを理解するのを手伝ってください。このようなエンティティ オブジェクトのインスタンスを取得する方法はありますか?

4

1 に答える 1

4

の一意の識別子に基づいてと の間ProjectDetailで変換できるように、コンバータをそのように記述する必要があります。通常、エンティティには. これを値として使用する必要があります。null や instanceof などの簡単なチェックを行わないキックオフの例を次に示します。StringProjectDetailidString

@Override
public String getAsString(FacesContext context, UIComponent component, Object value) {
    // Convert ProjectDetail to its unique String representation.
    ProjectDetail projectDetail = (ProjectDetail) value;
    String idAsString = String.valueOf(projectDetail.getId())
    return idAsString;
}

@Override
public Object getAsObject(FacesContext context, UIComponent component, String value) {
    // Convert unique String representation of ProjectDetail back to ProjectDetail object.
    Long id = Long.valueOf(value);
    ProjectDetail projectDetail = someProjectDetailService.find(id);
    return projectDetail;
}

JSF コンバーター (およびバリデーター) で EJB を使用するには、ハッカーが必要であることに注意してください。@FacesConverter で @EJB、@PersistenceContext、@Inject、@Autowired などを注入する方法も参照してください。

于 2012-06-10T13:40:16.507 に答える