Evet güzel ve sık karşılaşılan bir problem.
Bununla ilgili çözümlerden birisi
Sn. Bilgisayarcı'nın anlattığı gibi sorguyu excel'e göndermek.
Benim kullandığım diğer çözümler ise kodlama ile sağlanabiliyor.
Crosstab Query'de kaç tane alan olduğunu ve hangi alan isimlerinin olduğunu Kod yazarak alabiliyorsunuz.
Internet'te yaptığım bir araştırmada,
Bununla ilgili bir çözüm bulmuştum.
Biraz ingilizceniz varsa çözebilirsiniz.
Yapılan şey özetle şu;
Raporda önceden sabit alanlar oluşturup,
kodla çapraz sorgudan alınan değerlere göre sırasıyla atamak.
----------------------
Title: Crosstab Query Report - asked by dhemple on 06/08/2004 12:16PM PDT
http://www.experts-exchange.com/Database...18004.html
I have a report that is populated with a crosstab query. The
Column headings will change depending on the criteria selected by the user, but there will always be 5 columns.
Sample1:Product Desc 1Qtr03 2Qtr03 3Qtr03 4Qtr03
Sample2:Product Desc 3Qtr03 4Qtr03 1Qtr04 2Qtr04
------------------------------------------------------------------------------
Quote from Nic’s really old thread:
“When the selected field for the
Column value can have different value's, you'll need some code to fill the columns as the value from the fields becomes the NAME of the field for the report.
Checkout this code / comment I created for another Q:
Making the columnheader and detaildata flexible is possible, but needs some
Vba code in the OpenReport event.
To start, doing this you need to place the fields "coded" in the report.
The
Column headings should be called "lblCol1", "lblCol2", "lblCol3", etc.
The "detail" fields should be called "Col1", "Col2", "Col3", etc.
The report query has two rowheader columns and a Total column, therefor the first field is effectively
Column 4 (count starts at 0 so I used intI=3) but this could differ for you.
Make sure that the number of Columns is not bigger as the number placed. The programcode has no protection against that !
The OpenReport code:
---------------------------------------------------------------------------
Private Sub Report_Open(Cancel As Integer)
Dim intI As Integer
Dim intR As Integer
Dim rs As Recordset
Set rs = CurrentDb.OpenRecordset(Me.RecordSource)
'Place headers
For intI = 3 To rs.Fields.Count - 1
Me("lblCol" & intI - 1).Caption = rs.Fields(intI).Name
Next intI
'Place correct controlsource
For intI = 3 To rs.Fields.Count - 1
Me("Col" & intI - 1).ControlSource = "=SUM([" & rs.Fields(intI).Name & "])"
Next intI
'Place Total field
Me.ColTotal.ControlSource = "=SUM([" & rs.Fields(2).Name & "])"
End Sub
---------------------------------------------------------------------------
The report query has two rowheader columns and a Total column, therefor the first field is effectively
Column 4 (count starts at 0 so I used intI=3) but it could differ for you. PRC_Cross Nic;o)”