Mam domenę "kraj" i na liście listy przeszukuję blok wyszukiwania z polem wprowadzania. Pierwszy problem polegał na tym, że gdy próbowałem użyć paginate na mojej liście zawsze pokazywałem wszystkie wyniki, w tym przypadku używam rozwiązania i wysłałem tylko 10 wartości do wyświetlenia (jeśli znasz inne rozwiązanie, proszę powiedz mi). Moje poszukiwania wygląda następująco:paginacja paginacji wyników wyszukiwania
def search = {
if(query){
def srchResults = searchableService.search(query, params)
def result = Country.executeQuery("select new map(a.name as name, a.datacenter as datacenter) from Country a where a.name like '%"+ params.q + "%'")
if (params.offset)
{
x = params.offset.toInteger()
y = Math.min(params.offset.toInteger()+9, result.size()-1)
} else
{
x = 0
size = result.size() - 1
y = Math.min(size, 9)
}
def q=params.q
[countryInstanceList: result.getAt(x .. y), countryInstanceTotal:result.size(), q:params.q]
}else{
redirect(action: "list")
}
}
Teraz mam inny problem, po naciśnięciu na następnej stronie następnie moje params z pola wyszukiwania jest sprzątanie, a wynik jest zerowy. Próbowałem wysłać wartość pola jako parametr, ale coś robię źle.
Moja strona wyszukiwania wygląda następująco:
<g:form action="search">
<div class="search" >
Search Country
<g:hiddenField name="q" value="${params.q}" />
<input type="text" name="q" value="${params.q}" />
<input type="submit" value="Search"/>
</div>
</g:form>
...... ......
Emmmm, dlaczego korzystasz z wyszukiwarki, a później używasz zapytania HQL? –