我想为我的表添加数据过滤器。有人能帮助我吗? 我已经为列表控制器编写了代码,但我没有 知道如何在我的.gsp文件中实现“mitarbeiterSelectedId”。
目前我有以下代码段。
这是我的控制器'列表'
def list(Integer max) {
def mitarbeiterList = Mitarbeiter.listOrderByNachname()
if (params.selectedMitarbeiterId != null && params.selectedMitarbeiterId != '-1'){
mitarbeiterList = [Mitarbeiter.findById(params.selectedMitarbeiterId)]
}
[mitarbeiterInstanceList: mitarbeiterList, mitarbeiterInstanceTotal: Mitarbeiter.count() ]
}
这是我的list.gsp
<g:select id="mitarbeiter" name="mitarbeiterId" from="${Mitarbeiter.list()}" optionValue="nachname"
optionKey="id"
noSelection="${['-1': 'Bitte auswählen...']}" onchange="selectedMitarbeiterId"/>
<g:actionSubmit value="submit" onclick="" >OK</g:actionSubmit>
<table>
<thead>
<tr>
<g:sortableColumn property="nachname" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiter.nachname.label', default: 'Nachname')}"/>
<g:sortableColumn property="vorname" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiter.vorname.label', default: 'Vorname')}"/>
<g:sortableColumn property="sollpensum" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiterHistory.sollpensum.label', default: 'Sollpensum')}"/>
<sec:ifAllGranted roles="ROLE_ADMIN">
<g:sortableColumn property="gehalt" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiterHistory.gehalt.label', default: 'Gehalt')}"/>
</sec:ifAllGranted>
<th><g:message code="mitarbeiterHistory.bereich.label" default="Bereich"/></th>
</tr>
</thead>
<tbody>
<g:each in="${Mitarbeiter.list()}" status="i" var="mitarbeiterInstance">
<tr class="${(i % 2) == 0 ? 'even' : 'odd'}">
<td><g:link action="show" controller="mitarbeiter"
id="${mitarbeiterInstance.id}">${fieldValue(bean: mitarbeiterInstance, field: "nachname")}</g:link></td>
<td>${fieldValue(bean: mitarbeiterInstance, field: "vorname")}</td>
<td>${fieldValue(bean: mitarbeiterInstance.histories, field: "sollpensum")}</td>
<sec:ifAllGranted roles="ROLE_ADMIN">
<td>${fieldValue(bean: mitarbeiterInstance.histories, field: "gehalt")}</td>
</sec:ifAllGranted>
<td>${fieldValue(bean: mitarbeiterInstance.histories, field: "bereich")}</td>
</tr>
</g:each>
</tbody>
</table>
有人可以帮我解决这个问题吗?
好的,现在我的班级看起来像这样。
class Employee{
String firstname
String lastname
static hasMany = [histories:EmployeeHistory]
static constraints = {
firstname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
lastname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
}
}
所以当我插入你的代码时,它看起来像这样:
class Employee{
String firstname
String lastname
static hasMany = [histories:EmployeeHistory]
static constraints = {
firstname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
lastname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
}
static namedQueries = {
filteronLastname { String inLastname ->
if (inLastname && inLastname?.size() > 0) {
ilike 'lastname', "%${inLastname}%"
}
}
}
}
如果在下拉列表中未选择任何内容,我想显示整个表格数据 如果我在下拉列表中选择一名员工,我只想显示包含所选员工数据的表格。
目前这是我的员工名单控制员
def list() {
params.max = Math.min(params.max ? params.int('max') : 10, 100)
def employeeList = Employee.filteronLastname(params?.lastName).list(params)
[employeeInstanceList: employeeList, employeeInstanceTotal: employeeList.totalCount ]
}
我必须在哪里插入:
NewsItem.filterLastname(params?.Lastname).
list()
以及如何更改<g:selected>
?
答案 0 :(得分:0)
为了过滤数据,我们最近采用了另一种方法。为了实现灵活的过滤可能性,我们使用namedqueries实现了过滤方法。
一个带有一些随机代码的小例子,解释了这个想法!:
class NewsItem {
String title
String message
static namedQueries = {
filteronTitleILike { String inTitle ->
if (inTitle && inTitle?.size() > 0) {
ilike 'title', "%${inTitle}%"
}
}
filteronMessageILike { String inMessage ->
if (inMessage && inMessage ?.size() > 0) {
ilike 'message', "%${inMessage }%"
}
}
}
}
要使用过滤,我们现在可以执行以下操作:
NewsItem.filterOnTitleILike(params?.title).
filterOnMessageILike(params?.message).
list()
使用此方法的一个主要优点是,当数据从gsp发送到控制器时,我们非常灵活。如果params?.title没有填充aka null,那么在namedquery中不考虑这个。因此,我们只提供参数?。消息它保持完美!