2

我是coldfusion的新手,我坚持在函数中循环查询。例如,我有一个函数,其中有一个查询,该查询返回以“a”开头的名称。但我只能从数据库中获取一个值(第一个值)。实际上,在数据库中,我们有多个用于此查询的值。我应该如何在函数中循环查询?任何帮助表示赞赏...

<cffunction name="getNames" returntype="any">
<cfargument name="letter" required="true">
<cfquery name="getNamesfrmDB" datasource="test">
select * from employee where firstname like '#arguments.letter#%'
</cfquery>  

<cfreturn getNamesfrmDB/>
</cffunction>
<cfoutput>#getNames('a').firstname#</cfoutput>

提前致谢...

4

1 回答 1

2

啊。我准备好你的问题错了......忽略以前的答案..

您将查询直接从函数中传递出来,因此它将作为查询出现,您可以这样对待它。

在您的 cfouptut 中使用 query="qname"

<cffunction name="getNames" returntype="any">
        <cfargument name="letter" required="true">
        ... your query ..
        <cfreturn getNamesfrmDB/>
    </cffunction>

    <!---call the function--->
    <cfset names = getNames('a')>

    <!---now loop over the results using cfoutput--->
    <cfoutput query="names">
        <p>#firstname#</p>
    </cfoutput>

    <!---OR ALTERNATIVELY, as you can't use cfoutput inside cfoutput.. so if you are already inside a cfouput, you can also output query results using cfloop--->
    <cfoutput>
        ..some other stuff...
        <cfloop query="names">
            <p>#firstname#</p>
        </cfloop>
        ..some other stuff..
    </cfoutput>
于 2011-11-16T09:50:22.140 回答