抱歉,如果这是一个很糟糕的问题,但是这一功能使我发疯了好几天了,所以我想把身份证贴在这里,看看你们是否可以帮助我
基本上,我想从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方法调用数据库。