1

@Gordon Linoffからの回答に続く最初の編集については、以下を参照してください

2番目の編集/乱雑なソリューションについては、下部を参照してください

元の質問

3 つのテーブルがあります。

tblOrganisations
tblOrganisationTypes
tblOrganisationSubTypes

組織はタイプを持つことができ、一部のタイプはサブタイプを持つことができます

タイプとサブタイプのリストとカウントを取得しようとしていますが、タイプにサブタイプがある場合のカウントに問題があります。

次のクエリとコード。

<CFQUERY NAME="RetrieveAllOrganisationTypes" DATASOURCE="#strDev#">
    SELECT tblOrganisations.tblOrganisationTypes_ReferenceID , COUNT(tblOrganisations.tblOrganisationTypes_ReferenceID) AS TypeCount , COUNT(tblOrganisations.tblOrganisationSubTypes_ReferenceID) AS SubTypeCount , tblOrganisationTypes.OrganisationType , tblOrganisationSubTypes.OrganisationSubType
            FROM (( tblOrganisations
            LEFT JOIN tblOrganisationTypes ON tblOrganisations.tblOrganisationTypes_ReferenceID = tblOrganisationTypes.ReferenceID )
            LEFT JOIN tblOrganisationSubTypes ON tblOrganisations.tblOrganisationSubTypes_ReferenceID = tblOrganisationSubTypes.ReferenceID )
            GROUP BY tblOrganisations.tblOrganisationTypes_ReferenceID , tblOrganisations.tblOrganisationSubTypes_ReferenceID
            ORDER BY tblOrganisationTypes.OrganisationType , tblOrganisationSubTypes.OrganisationSubType
</CFQUERY>

<CFOUTPUT QUERY="RetrieveAllOrganisationTypes" GROUP="OrganisationType">
    #OrganisationType# (#TypeCount#)<BR>
    <CFIF OrganisationSubType IS NOT ""><CFOUTPUT GROUP="OrganisationSubType">-- #OrganisationSubType# (#SubTypeCount#)<BR></CFOUTPUT></CFIF>
</CFOUTPUT>

これを取得します。

AFFILIATED (2)
ASSOCIATE (15)
FULL (10)
-- operator (10)
-- manufacturer (4)
-- owner (108)
-- survey company (4)
-- supplier (4)
GOVERNMENT (5)
MISCELLANEOUS (3)
SCIENCE (4)

しかし、ご覧のとおり、Full count - 10 - は間違っています。130のはずです!SubType のないタイプの場合、カウントは正しいです。SubTypes の数は正しいです。私はあらゆる種類のものを試しましたが、どこにも行きません:(

どんな助けでも大歓迎です!:)

1回目の編集

@Gordon Linoff のヘルプに従って、WITH ROLLUP を追加し、ORDER BY を削除して、次のコードを使用します。

<CFOUTPUT QUERY="RetrieveAllOrganisationTypes" GROUP="OrganisationType">
    #OrganisationType# (#TypeCount#) #SubTypeCount#<BR>
    <CFIF OrganisationSubType IS NOT ""><CFOUTPUT GROUP="OrganisationSubType">-- #OrganisationSubType# (#TypeCount#) #SubTypeCount#<BR></CFOUTPUT></CFIF>
</CFOUTPUT>

私は今得ます。

AFFILIATED (2) 2
ASSOCIATE (15) 15
FULL (10) 10
-- operator (10) 10
-- manufacturer (4) 4
-- owner (108) 108
-- survey company (4) 4
-- supplier (4) 4
-- (130) 130
GOVERNMENT (5) 5
MISCELLANEOUS (3) 3
SCIENCE (4) 4
(159) 159

130 を取得していることがわかりますが、フルで 130 を取得するにはどうすればよいですか?!

2回目の編集/厄介な解決策

だから、これはちょっと厄介な解決策だと思いますが、うまくいきます!

次の出力コード。

<CFOUTPUT QUERY="RetrieveAllOrganisationTypes" GROUP="OrganisationType">
    <CFOUTPUT GROUP="OrganisationSubType">
    <CFIF OrganisationSubType IS "" AND OrganisationType IS NOT "">#OrganisationType# (#TypeCount#)<BR></CFIF>
    </CFOUTPUT>
    <CFOUTPUT GROUP="OrganisationSubType">
    <CFIF OrganisationSubType IS NOT "" AND OrganisationType IS NOT "">--#OrganisationSubType# (#SubTypeCount#)<BR></CFIF>
    </CFOUTPUT>
</CFOUTPUT>

私に与えます;

AFFILIATED (2)
ASSOCIATE (15)
FULL (130)
--operator (10)
--manufacturer (4)
--owner (108)
--survey company (4)
--supplier (4)
GOVERNMENT (5)
MISCELLANEOUS (3)
SCIENCE (4)

おそらくこれを行うためのよりクリーンな方法があると確信しています。誰かがそれを知っていれば、提案を受け付けていますが、今のところ-これは機能しています:)

4

1 に答える 1