Weird Problem with a Subreport

C

Chels

You guys have saved me before so I hope you can do it again! I am using
Access 2000. I am trying to create a report that will display two lists of
Unit numbers with remarks for each Unit number. I want the lists to be one
after the other but I would also like them to be in columns because the data
is not very detailed but there are a lot of units.

I have had no problem with creating one report displayed in 3 columns for
one list of numbers. I thought I could add a subreport with the other list of
numbers and it would put it at the end of the first list. That didnt work.
The Subreport will only show as many rows as will fit in the area I delegated
for the subreport in design view. Also the subreport keeps putting itself in
numerical order using the first unit number in it's list. I don't know how it
is doing it but I want it to go at the end of the first list.

Then I tried making a report with a subreport for each list. The first
subreport goes in fine. Then the second subreport (the one I tried adding as
a subreport in my first attempt) again will only show the number of units it
can fit in the area it's given and it keeps putting itself in order. I even
tried putting these subreports side by side in design view to see if it would
give me two lists side by side but again it will only show the limited units
and it is STILL putting itself in numerical order with the first just beside
it.

Does anyone know why these things are happening? I have never tried using
subreports so maybe i am doing this totally wrong? I am adding the subreports
to the "details" section so this is also making me have HUGE spaces between
entries. Also it doesnt matter if the page is setup to be in columns or not I
get the same problems.

Thank you for any help!
 
K

Klatuu

Have you tried using a Union query to join the two lists together and using
that as the record source of the report?
 
C

Chels

Will that allow me to keep the two lists seperate? They can't be mixed
together. Also would it be possible to put a label before the second list
starts?
 
K

Klatuu

The two lists are separate. That is why you could use a Union query to put
the together on one report. You will have to make sure you can order the
union query so the lists are in the order you want. Also, to present a lable
between lists and to keep the list separate, you could use the report
Sorting and Grouping and group by the list identifier. The use a Group
Header and you can put a label in the group header.

Here is an example of how to use the Union Query to identify the lists:

SELECT 0 AS ListID, SomeField, AnotherField, AnyField FROM FirstList;
UNION ALL
SELECT 1 As ListID, SomeField, AnotherField, AnyField FROM SecondList;

The output of your query will now have a field named ListID. You would
group on ListID and sort on ListID in the report.

Here is an example where I do exactly this in a report. Note the first
calculated field is used to sort the two and the second field is what I use
for the Group Header Labels:

SELECT 0 As GroupType, "Active Contracts With No Start Date" As
Group_Description, ContractType, ClientName, PropertyName FROM
qselMonActRptNoStart;
UNION ALL SELECT 1 As GroupType, "InActive Contracts With No End Date" As
Group_Description, ContractType, ClientName,PropertyName FROM
qselMonActRptNoEnd;
 
C

Chels

Thank you so much! Using the union query to identify the lists worked
wonderfully. I am running into more problems now though.

I have another field I usually put in my queries just for sorting to keep
everything in order because the Unit #s dont keep themselves in the proper
order. How can i tell the query to sort with a field but not show it? When I
view the query everything is in the right order but when I view the report
they're not. Also I am a little confused as to how to do the grouping so
there is a header between the two lists. I did find the sorting and grouping
and i told it to group based on List ID. This is what I have

ListID Group Properties: ( I have List ID sorting Ascending, I dont know if
I should but I can't figure out how to tell it not to sort)
Group Header: Yes
Group Footer: No
Group On: Each value (Is this correct?)
Group Interval: 1 (?)
Keep together: No

I have a header of shutdown in front of the whole list but the two lists
arent sorting properly or seperating like they are in the query list.
 
K

Klatuu

You group settings are correct. You should be grouping by GroupType. The
field I showed in my example that separates the list. You can also use the
sorting and grouping to order the groups. Just create another group below
the first group, but don't identify any headers or footers for the group.
 
C

Chels

OK you lost me a bit....
So the settings for my grouping are all fine? What do you mean by "You
should be grouping by groupType"?

How do I make a second group below? Am I making these groups to tell them
which records to put in which group? I dont really understand the properties
very much, sorry. Am I telling it to group ListID 0 together and ListID 1 in
another group? Will I need to add anything to my query?

If I am not understanding you sorry I am new to the grouping thing!
 
C

Chels

OK scratch that! The grouping is working.... I didnt have to change anything
I just didnt notice it was working the first time. What confused me is it is
putting the group header in front of both groups. I only want to header in
front of the second group. How do I get the first header to go away? Do I
need to put that first list in it's own group without a header?

I still dont know what to do about the sorting though.... should i add my
sorting field to the query? If so can I tell the query not to make the
sorting field visible or do I need to do that in the report like I did with
the List ID field?
 
K

Klatuu

If you don't want to show the header on the first group, you can use some
simple VBA to do that.
Open the report in design view.
Right Click on the group header and you will get the properties dialog
Select the Events Tab
Select On Format by clicking on the small command button to the right of it
with the 3 dots.
Select Code Builder.

The VBA editor will open with the cursor positioned in the sub.
Enter the following (sort of, I'll show the differences next)

If Me.txtGroupType = 0 Then
Me.GroupHeader1.Visible = False
Else
Me.GroupHeader1.Visible = False
End If

Now the differences.
txtGroupType is the name of the text box where you will show the group
type or the group description.
= 0 should be the value you will expect for the first group
GroupHeader1 is usually the default name for the first group header.

That should take care of hiding the header for the first group.

As to the sorting after that. I would not bother to sort the query. You
can use the next Group in the Sorting and Grouping dialog. It will sort on
whatever field or fields you select, but not including the first one already
identifyed. So everything that starts with 0 (using my example), will be in
the first group, but then if you use say contract type(using my example), The
report will show the contract type in order for each group. For example:
0 A
0 B
0 C
Group 1
1 A
1 C
1 D

Just don't select a group header or footer for the contract group.
 
C

Chels

Ok I have this as the Code for the Group Header:

Private Sub GroupHeader0_Format(Cancel As Integer, FormatCount As Integer)
If Me.txtGroupType = 0 Then
Me.GroupHeader1.Visible = False
Else
Me.GroupHeader1.Visible = False
End If
End Sub

It is not working. I have never tried using VBA code before. I only have the
one group should I have two?

The problem with the sorting is that the field I usually use for sorting is
not in the query or report. It is just a number assigned to each entry to
keep them all in the proper order because none of the information in the
records can be used for sorting. I usually include it in the queries (It is
called Place Holder) but don't make it visible and then when I make the
reports from those queries everything is usually in the right order. When I
tried to include that field in the Union query it keeps putting it in as
blank and asking for a parameter value.
 
K

Klatuu

Should be
If Me.txtGroupType = 0 Then
Me.GroupHeader1.Visible = False
Else
Me.GroupHeader1.Visible = True
End If
End Sub

No, you don't need a second one.
Do you have a text box in the Goup Header?
What is the name of the text box and which field in the query is it bound to?

If you don't have a field to sort on, how do you know it is not sorting
correctly?
You can't sort without at least one field.
 
C

Chels

OK I somehow got that VBA code to work! Thank you!!! To answer your
questions....

I have a label as the group header, is that wrong? It's not bound to
anything... Is that why i am having problems with this? I dont know how to
use text boxes....I just use labels because I didnt understand the whole
Text#: Unbound thing as seperate boxes.

Ok for the sorting i will try to explain it to you. My main table in my
database is a list of tests that each have their own Unit #, the unit numbers
are all weird though they all have numbers, come also have letters like P1
for part 1 of a test or R or E if they're a different kind of test but they
all do make sense in an order. The sorting gets confused i think by the
letters and puts it in weird orders such as

UNIT
1
10
11
12
2
29 P1
29 P2
3
30
31 P2

The Place Holder field I made just to keep all of the Unit numbers in the
right order. I usually include Place Holder in all of my querys but put it as
not visible just to keep everything in order and then reports from those
queries are also always in order. Because you told me how to make the Union
query by writing the SQL I didnt include the Place holder field, I thought it
would just keep itself in order because the two queries I made the Union
query from are being sorted by the place holder field. Does that make sense?

I have a feeling I am making things harder for myself because I dont fully
understand how to use this program.
 
K

Klatuu

Yes, but you are learning

You can use a label.. All you need to do is make the label visible or
invisible.
labels are not intended to hold data. That is what text boxes are for.
Lables are for identifying the context of the data or providing static
information to the user.

As to the sort. You can include the place holder and leave it visible. That
doesn't mean you have to show it on the report. You can just use if for the
sorting and grouping.
 
C

Chels

Thank you so much. I definitely am learning you area big help! Believe it or
not i did take a course in this program, a lot of help that was!

So how do you make text boxes bound to something?

I tried to add Place Holder to the Union query along with UNIT, Remarks but
it will not work. It wouldnt accept it with a space between the words. I
tried using an underscore between them and it accepted that but it is not
showing any numbers and just asks me for a parameter value. Does this mean it
can't find the information for that field?
 
K

Klatuu

You bind a field in a form or report's record source to the control source
property of the text box. This is the same for all controls that can contain
data. A label can't. (Well, you can make it show a data item, but that would
be a waste)

As to the SQL problem, post back with the SQL and we will have a look.
 
C

Chels

SELECT 0 AS ListID, UNIT, Remarks, Place_Holder FROM AugustND;
UNION ALL SELECT 1 As ListID, UNIT, Remarks, Place_Holder FROM
AugustShutdownND;

That is what I have and it just asks me for a Parameter value for Place
Holder. Place Holder is definitely in the AugustND and AugustShutdownND
queries and it's visible and all that. I don't know about the spacing thing
though. It's name is Place Holder but the query won't accept that with a
space so I have tried the _ and also no space and it does the same thing.
 
K

Klatuu

Looks normal enough. Is Place_Holder a field in the tables? It has to be
either that, or a calculated field. 0 AS ListID is an example of a
calculated field. It can be any reasonable expression or even a VBA Public
function. It just returns a value with the name of the column using the As
 
C

Chels

SUCCESS!!!!!!!!!
SELECT 0 AS ListID, UNIT, Remarks, [Place Holder] FROM AugustND;
UNION ALL SELECT 1 As ListID, UNIT, Remarks, [Place Holder] FROM
AugustShutdownND;
This worked! That is how it has all of the fields in SQL view of the
queries I've made in design view. It just occured to me to check them. Seeing
how those work is helpful but it looks very different from how you write
these ones.
I viewed the field list, added Place holder to my report, made it invisible
and used sorting and grouping to sort by the placeholder and all is well!!!!

Thank you so much for teaching me how to do this and helping me make this
report exactly the way I needed it! I am sure the reactor will be very
thankful for your help with making these testing schedules! haha. Now I just
need to make 11 more just like this....
 
K

Klatuu

Doh! I should have seen the spaces. Sorry.
Spaces should not be in names, see what happens?
what is a reactor? Nothing that will create a mushroom cloud, I hope.
So why 11 more?
Tell me about them. It is very likely we really only need one with some
tweeks to make it think there are 11. I do that all the time. If you can,
it saves a lot of work now and in the future when changes or enhancements are
required.

Would you rather do it 12 times or 1? :)
--
Dave Hargis, Microsoft Access MVP


Chels said:
SUCCESS!!!!!!!!!
SELECT 0 AS ListID, UNIT, Remarks, [Place Holder] FROM AugustND;
UNION ALL SELECT 1 As ListID, UNIT, Remarks, [Place Holder] FROM
AugustShutdownND;
This worked! That is how it has all of the fields in SQL view of the
queries I've made in design view. It just occured to me to check them. Seeing
how those work is helpful but it looks very different from how you write
these ones.
I viewed the field list, added Place holder to my report, made it invisible
and used sorting and grouping to sort by the placeholder and all is well!!!!

Thank you so much for teaching me how to do this and helping me make this
report exactly the way I needed it! I am sure the reactor will be very
thankful for your help with making these testing schedules! haha. Now I just
need to make 11 more just like this....
--
Chels


Klatuu said:
You bind a field in a form or report's record source to the control source
property of the text box. This is the same for all controls that can contain
data. A label can't. (Well, you can make it show a data item, but that would
be a waste)

As to the SQL problem, post back with the SQL and we will have a look.
 
C

Chels

Indeed it is a reactor of the nuclear variety. It would cause a mushroom
cloud if things went wrong. It has been running pretty smoothly for 50 years
now so it should be fine. We supply most of Ontario, (possibly even Canada,
I'm not sure I'm just a college student working here for the summer) with
radioactive isotopes for any medical procedure that would require them; such
as radiation therapy to treat cancer.

Ok spaces in names bad! haha.

Ok what you just helped me make is a list of all of the tests that need to
be done to the reactor in the month of august. Hence why it was so important
that the list of tests than need to be done during reactor shutdown be
seperate from the others. Now I need to make reports for the lists for all
of the other eleven months! I was just going to make more queries and then do
a save as for the reports and just change which query they are getting the
info from and then change the titles. Is there an easier way?
--
Chels


Klatuu said:
Doh! I should have seen the spaces. Sorry.
Spaces should not be in names, see what happens?
what is a reactor? Nothing that will create a mushroom cloud, I hope.
So why 11 more?
Tell me about them. It is very likely we really only need one with some
tweeks to make it think there are 11. I do that all the time. If you can,
it saves a lot of work now and in the future when changes or enhancements are
required.

Would you rather do it 12 times or 1? :)
--
Dave Hargis, Microsoft Access MVP


Chels said:
SUCCESS!!!!!!!!!
SELECT 0 AS ListID, UNIT, Remarks, [Place Holder] FROM AugustND;
UNION ALL SELECT 1 As ListID, UNIT, Remarks, [Place Holder] FROM
AugustShutdownND;
This worked! That is how it has all of the fields in SQL view of the
queries I've made in design view. It just occured to me to check them. Seeing
how those work is helpful but it looks very different from how you write
these ones.
I viewed the field list, added Place holder to my report, made it invisible
and used sorting and grouping to sort by the placeholder and all is well!!!!

Thank you so much for teaching me how to do this and helping me make this
report exactly the way I needed it! I am sure the reactor will be very
thankful for your help with making these testing schedules! haha. Now I just
need to make 11 more just like this....
--
Chels


Klatuu said:
You bind a field in a form or report's record source to the control source
property of the text box. This is the same for all controls that can contain
data. A label can't. (Well, you can make it show a data item, but that would
be a waste)

As to the SQL problem, post back with the SQL and we will have a look.
--
Dave Hargis, Microsoft Access MVP


:

Thank you so much. I definitely am learning you area big help! Believe it or
not i did take a course in this program, a lot of help that was!

So how do you make text boxes bound to something?

I tried to add Place Holder to the Union query along with UNIT, Remarks but
it will not work. It wouldnt accept it with a space between the words. I
tried using an underscore between them and it accepted that but it is not
showing any numbers and just asks me for a parameter value. Does this mean it
can't find the information for that field?
--
Chels


:

Yes, but you are learning

You can use a label.. All you need to do is make the label visible or
invisible.
labels are not intended to hold data. That is what text boxes are for.
Lables are for identifying the context of the data or providing static
information to the user.

As to the sort. You can include the place holder and leave it visible. That
doesn't mean you have to show it on the report. You can just use if for the
sorting and grouping.
--
Dave Hargis, Microsoft Access MVP


:

OK I somehow got that VBA code to work! Thank you!!! To answer your
questions....

I have a label as the group header, is that wrong? It's not bound to
anything... Is that why i am having problems with this? I dont know how to
use text boxes....I just use labels because I didnt understand the whole
Text#: Unbound thing as seperate boxes.

Ok for the sorting i will try to explain it to you. My main table in my
database is a list of tests that each have their own Unit #, the unit numbers
are all weird though they all have numbers, come also have letters like P1
for part 1 of a test or R or E if they're a different kind of test but they
all do make sense in an order. The sorting gets confused i think by the
letters and puts it in weird orders such as

UNIT
1
10
11
12
2
29 P1
29 P2
3
30
31 P2

The Place Holder field I made just to keep all of the Unit numbers in the
right order. I usually include Place Holder in all of my querys but put it as
not visible just to keep everything in order and then reports from those
queries are also always in order. Because you told me how to make the Union
query by writing the SQL I didnt include the Place holder field, I thought it
would just keep itself in order because the two queries I made the Union
query from are being sorted by the place holder field. Does that make sense?

I have a feeling I am making things harder for myself because I dont fully
understand how to use this program.

--
Chels


:

Should be
If Me.txtGroupType = 0 Then
Me.GroupHeader1.Visible = False
Else
Me.GroupHeader1.Visible = True
End If
End Sub

No, you don't need a second one.
Do you have a text box in the Goup Header?
What is the name of the text box and which field in the query is it bound to?

If you don't have a field to sort on, how do you know it is not sorting
correctly?
You can't sort without at least one field.
--
Dave Hargis, Microsoft Access MVP


:

Ok I have this as the Code for the Group Header:

Private Sub GroupHeader0_Format(Cancel As Integer, FormatCount As Integer)
If Me.txtGroupType = 0 Then
Me.GroupHeader1.Visible = False
Else
Me.GroupHeader1.Visible = False
End If
End Sub

It is not working. I have never tried using VBA code before. I only have the
one group should I have two?

The problem with the sorting is that the field I usually use for sorting is
not in the query or report. It is just a number assigned to each entry to
keep them all in the proper order because none of the information in the
records can be used for sorting. I usually include it in the queries (It is
called Place Holder) but don't make it visible and then when I make the
reports from those queries everything is usually in the right order. When I
tried to include that field in the Union query it keeps putting it in as
blank and asking for a parameter value.

--
Chels


:

If you don't want to show the header on the first group, you can use some
simple VBA to do that.
Open the report in design view.
Right Click on the group header and you will get the properties dialog
Select the Events Tab
Select On Format by clicking on the small command button to the right of it
with the 3 dots.
Select Code Builder.

The VBA editor will open with the cursor positioned in the sub.
Enter the following (sort of, I'll show the differences next)

If Me.txtGroupType = 0 Then
Me.GroupHeader1.Visible = False
Else
Me.GroupHeader1.Visible = False
End If

Now the differences.
txtGroupType is the name of the text box where you will show the group
type or the group description.
= 0 should be the value you will expect for the first group
GroupHeader1 is usually the default name for the first group header.

That should take care of hiding the header for the first group.

As to the sorting after that. I would not bother to sort the query. You
can use the next Group in the Sorting and Grouping dialog. It will sort on
whatever field or fields you select, but not including the first one already
identifyed. So everything that starts with 0 (using my example), will be in
the first group, but then if you use say contract type(using my example), The
report will show the contract type in order for each group. For example:
0 A
0 B
0 C
Group 1
1 A
1 C
1 D

Just don't select a group header or footer for the contract group.
--
Dave Hargis, Microsoft Access MVP


:

OK scratch that! The grouping is working.... I didnt have to change anything
I just didnt notice it was working the first time. What confused me is it is
putting the group header in front of both groups. I only want to header in
front of the second group. How do I get the first header to go away? Do I
need to put that first list in it's own group without a header?

I still dont know what to do about the sorting though.... should i add my
sorting field to the query? If so can I tell the query not to make the
sorting field visible or do I need to do that in the report like I did with
the List ID field?
--
Chels


:

OK you lost me a bit....
So the settings for my grouping are all fine? What do you mean by "You
should be grouping by groupType"?

How do I make a second group below? Am I making these groups to tell them
which records to put in which group? I dont really understand the properties
very much, sorry. Am I telling it to group ListID 0 together and ListID 1 in
another group? Will I need to add anything to my query?

If I am not understanding you sorry I am new to the grouping thing!
--
Chels


:

You group settings are correct. You should be grouping by GroupType. The
field I showed in my example that separates the list. You can also use the
sorting and grouping to order the groups. Just create another group below
the first group, but don't identify any headers or footers for the group.
--
Dave Hargis, Microsoft Access MVP


:

Thank you so much! Using the union query to identify the lists worked
wonderfully. I am running into more problems now though.

I have another field I usually put in my queries just for sorting to keep
everything in order because the Unit #s dont keep themselves in the proper
order. How can i tell the query to sort with a field but not show it? When I
view the query everything is in the right order but when I view the report
they're not. Also I am a little confused as to how to do the grouping so
there is a header between the two lists. I did find the sorting and grouping
and i told it to group based on List ID. This is what I have

ListID Group Properties: ( I have List ID sorting Ascending, I dont know if
I should but I can't figure out how to tell it not to sort)
Group Header: Yes
Group Footer: No
Group On: Each value (Is this correct?)
Group Interval: 1 (?)
Keep together: No

I have a header of shutdown in front of the whole list but the two lists
arent sorting properly or seperating like they are in the query list.
--
Chels


:

The two lists are separate. That is why you could use a Union query to put
the together on one report. You will have to make sure you can order the
union query so the lists are in the order you want. Also, to present a lable
between lists and to keep the list separate, you could use the report
Sorting and Grouping and group by the list identifier. The use a Group
Header and you can put a label in the group header.

Here is an example of how to use the Union Query to identify the lists:
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Top