抱歉,如果这是一个很糟糕的问题,但是这一功能使我发疯了好几天了,所以我想把身份证贴在这里,看看你们是否可以帮助我

基本上,我想从jsf页面执行的所有操作都是让用户搜索用户,并让我返回所有详细信息

<h:form id="searchForm">
                    <h:outputLabel value="Search: " style="font-weight:bold" />
                    <h:inputText id="search" value="#{userdetailsController.search}" />
                    <h:commandButton value="Search" action="index"/>

                </h:form>

那是jsf页面,工作正常

它调用了我的userdetailsController类
@Named("userdetailsController")
@SessionScoped
public class UserdetailsController implements Serializable {

    private Userdetails current;
    private DataModel items = null;
    @EJB
    private Richard.beans.UserdetailsFacade ejbFacade;
    private PaginationHelper pagination;
    private int selectedItemIndex;
    private String search;

    public String getSearch() {
        System.out.println("inGetSearch");
        return search;
    }

    public void setSearch(String search) {
        this.search = search;
    }
......

一个contactsService类
@Stateless
public class ContactsService {
    // Add business logic below. (Right-click in editor and choose
    // "Insert Code > Add Business Method")

    @EJB
    private UserdetailsFacade cf;

    public List<Userdetails> searchByString(String string) {
        return cf.searchByString(string);
    }


    public List<Userdetails> getAllPersons() {
        return cf.findAll();
    }
}

AbstractFacade类
   /* trying out a search function */
    public List<T> searchByString(String string) {
        System.out.println("in SearchByString");
        return getEntityManager().createNamedQuery("Userdetails.findByUsername").setParameter("string", "%" + string + "%").getResultList();
    }

和Userdetails类与我试图搜索的查询
 @NamedQuery(name = "Userdetails.findByUsername", query = "SELECT u FROM Userdetails u WHERE u.username = :username")})

当前只有 setter/getter 和设置在Getsearch中起作用

我已经花了几天时间在此功能上并且还没有关闭,我该如何使它正常工作,对不起,这是我第一次来此工作

谢谢你们

编辑

会添加
public List<Userdetails> getAllPersons() {
    if (search == null) {
        return cs.getAllPersons();
    }
    return cs.searchByString(search);
}

在UserdetailsController中足够了吗?

最佳答案

您没有在此处调用任何操作:

<h:commandButton value="Search" action="index"/>

因此,不执行任何操作确实合乎逻辑。

您需要调用一个托管bean操作,该操作又执行所需的代码以从DB中获取所需的数据并分配给一个属性:
<h:commandButton value="Search" action="#{userdetailsController.submit}" />

与内部UserdetailsController:
private String search;
private List<UserDetail> items; // No need for DataModel here.
@EJB
private UserdetailsFacade ejbFacade;

public String submit() {
    items = ejbFacade.searchByString(search);
    return "index";
}

整个ContactsService似乎没用。

根据您在问题更新中使用getter方法的尝试,请不要这样做。出于Why JSF calls getters multiple times中提到的原因,您永远不要使用getter方法调用数据库。

10-05 20:37
查看更多