我正在遍历查询的结果,我需要限制显示的行数。我需要使用cfoutput
,因为我使用group
属性,我不能使用maxrows
,因为不是所有的行都将显示。
我试图在<cfoutput>
内使用<cfbreak>
,但这会抛出一个错误。
如何跳出<cfoutput>
循环?
如果你的组by只是为了从你的结果中删除重复项,我建议使用你的查询来减少它们,然后你可以裁剪(选择distinct并减少返回的列列表)。
如果你正在使用你的group by来"分组"你的结果,你可以在你的循环中运行一个计数器,在你的第一个循环中运行一个cif语句来省略后面的结果。
如果您需要cfbreak
,您可以通过匹配前一行的值来在群集中创建组选项。<cfloop query="queryname">
<cfif queryname.column[currentrow-1] neq queryname.column[currentrow]>
#queryname.column#
</cfif>
</cfloop>
随机提示:您可以在任何/所有级别上对分组cfoutput进行maxrows
<cfset tmp = querynew('id,dd')>
<cfloop from="1" to="20" index="i">
<cfset queryaddrow(tmp,1)>
<cfset querysetcell(tmp,'id',rand(),i)>
<cfset querysetcell(tmp,'dd',(i mod 4),i)>
</cfloop>
<cfquery dbtype="query" name="tmp">select * from tmp order by dd</cfquery>
<cfoutput query="tmp" group="dd" maxrows="2">#dd#<br
<ul>
<cfoutput maxrows="2" group="id"><li>#id#</li></cfoutput>
</ul>
</cfoutput>
您可以使用cfthrow标记来触发一个异常,该异常将允许您使用cfcatch跳出循环,然后您可以忽略该异常并继续处理。这会给你你想要的。
<cftry>
<cfset i = 0>
<cfoutput query="qMyQuery" group="someGroup">
<cfset i = i + 1>
Parent
<cfoutput>
Child
</cfoutput>
<cfif i GTE 10>
<cfthrow type="break">
</cfif>
</cfoutput>
<cfcatch type="break">
<!--- DO NOTHING - THIS IS A HACK FOR NOT BEING ABLE TO USE CFBREAK inside cfoutput. --->
</cfcatch>
</cftry>