0

我有一个关于 cfspreadsheet 的问题......所以我正在使用 cfspreadshseet 创建用于报告目的的 excel 电子表格。我的页面允许用户从数据库中选择要包含在报告中的任何列。所以这里有一个例子:

电子表格可能如下所示:

名字---姓氏---组织---地址---城市---州---邮编---关注

Joe Smith Sample 12 主要 denver co 80513 关注点在这里

我的问题是,如果 Joe 有超过 1 个问题,我会得到多行包含 joe 的信息……有没有办法可以循环关注问题并且只有 1 行供 joe 使用?

谢谢,

史蒂夫

4

3 回答 3

2

使用 cfoutput 的“组”功能非常适合此任务。只是为了排除另一种可能性,您还可以在数据库查询中生成列表。

例如,MySQL 就有这个GROUP_CONCAT功能。我不知道您的表格的结构,但假设您有两个表格User,并且UserConcern您可以使用GROUP_CONCAT这样的方式将“关注”值连接成一个字符串:

SQLFiddle

SELECT
     u.UserID
     , u.FirstName
     , ... other columns
     , GROUP_CONCAT( uc.Concern ) AS ConcernList
FROM UserTable u INNER JOIN UserConcern uc
         ON uc.UserID = u.UserID
GROUP BY 
     u.UserID
     , u.FirstName
     , ... other columns

对于 SQL Server,一个标准技巧是使用 XML Path:

SQLFiddle

SELECT
     u.UserID
     , u.FirstName
     , ... other columns
     , STUFF( ( SELECT ',' + uc.Concern
                FROM  UserConcern uc
                WHERE uc.UserID = u.UserID
                ORDER BY uc.Concern
                FOR XML PATH('')
               ) 
              , 1, 1, ''
          ) AS ConcernList
FROM UserTable u
GROUP BY 
     u.UserID
     , u.FirstName
     , ... other columns

然后像往常一样简单地生成电子表格。

于 2014-10-19T17:29:42.233 回答
2

您需要一个唯一的行 ID 才能最安全地执行此操作,使用 lastname 或其他内容的外部组可能会导致冲突。UserID 是一个占位符变量。确保将其替换为准确的 ID 名称。当然,其中一些变量名只是猜测而已。

<cfoutput query ="thequery" group="UserID">
  <cfset cList="">
  <cfoutput group="concern">
    <cfset cList=ListAppend(cList,Concern)>
  </cfoutput>
  <cfset temp = spreadsheetAddRow(my_spreadsheet,"'#fn#','#ln#',...,'#cList#'">
</cfoutput>
于 2014-10-19T06:38:18.177 回答
0

假设您想要为每个评论单独的行,这样的事情会起作用:

<cfset current_id = "">
<cfloop query = "my_query">
    <cfset next_id = user_id>
    <!--- or whatever else forms the primary key --->
    <cfif next_id neq current_id>
        <cfset current_id = next_id>
        <cfset SpreadsheetAddRow(my_spreadsheet, "#first_name#,#last_name#,etc, #comment#">
    <cfelse>
        <cfset SpreadsheetAddRow(my_spreadsheet, ",,#comment#">
    </cfif>
</cfloop>

这是基于提供的信息。如果您有唯一的 ID,则组属性会更好。

于 2014-10-19T04:25:10.367 回答