so many queries within queries I'm confused

A

Abby Lee

1st sorry about leangth...couldn't really cut anymore.

I want the output to be
Organization 320000
Fund 100004
Program 777777
Account1 7234.55
Account2 -347.99
Account3 823.55

Program 888888
Account1 8745.99
Account2 -9878.33
.....on and on.

<b>What I can get to work is</b>
Organization 320000
Fund 100004
Program 777777
Account1 7234.55

Organization 320000
Fund 100004
Program 777777
Account2 -347.99
.........on and on.

The code below looks right but the Organization, Fund, Program numbers
never change when they should. I've been looking at this for two
days...help!

<table border="0">
<%
sSQL3 = "SELECT Distinct Organization" & _
" FROM " & TheYear & _
" WHERE MonthPD = '" & ThePD & "'"
set rs3 = Connect.Execute(sSQL3)
%>
<tr>
<td> <font color="#0000FF">Organization </font></td>
<td colspan="10"><%=rs3("Organization")%></td>
</tr>
<% Do until rs3.eof %>
<%
sSQL2 = "SELECT Distinct Fund" & _
" FROM " & TheYear & _
" WHERE MonthPD = '" & ThePD & "'"
set rs2 = Connect.Execute(sSQL2)
%>
<tr>
<td> <font color="#0000FF">Fund </font></td>
<td colspan="10"><%=rs2("Fund")%></td>
</tr>
<% Do until rs2.eof %>
<%
sSQL4 = "SELECT Distinct Program, Fund, Organization" & _
" FROM " & TheYear & _
" WHERE MonthPD = '" & ThePD & "'" & _
" ORDER BY Organization, Fund, Program"
set rs4 = Connect.Execute(sSQL4)
TheProg = rs4("Program")
%>
<tr>
<td> <font color="#0000FF">Program</font> </td>
<td colspan="10"><%=TheProg%></td>
</tr>
<% Do until rs4.eof %>
<tr>
<td>Account</div></td>
<td><%=TheAct%> </td>
<td><%=TotalAmt%></td>
</tr>
<%
TheFund = rs4("Fund")
TheOrg = rs4("Organization")
TheProg = rs4("Program")
SQL = "SELECT *" & _
"FROM " & TheYear & _
"WHERE MonthPD = '" & ThePD & "'" & _
" and Organization = '" & TheOrg & "'" & _
" and Fund = '" & TheFund & "'" & _
" and Program = '" & TheProg & "'" & _
" ORDER BY Account"
set rs = Connect.Execute(sSQL)
TotalAmt=0
Do until rs.eof
TheAct = rs("Account")
TotalAmt = TotalAmt + rs("PdAmount")

Response.Flush
rs.MoveNext
Loop

Response.Flush
rs4.MoveNext
Loop

Response.Flush
rs2.MoveNext
Loop

Response.Flush
rs3.MoveNext
Loop %>
</table>
 
A

Aaron [SQL Server MVP]

You can do this with a single recordset (see http://www.aspfaq.com/2241 ).
I'll leave the HTML pretty-ifying up to you.

<%
sql = "SELECT Organization, Fund, Program, Account, PdAmount" & _
"FROM " & TheYear & _
" ORDER BY Organization, Fund, Program, Account"

cOrg = "": cFund = "": cProg = "": cAcc = ""

set rs = conn.execute(sql)

do while not rs.eof
nOrg = rs(0): nFund = rs(1): nProg = rs(2)
nAcc = rs(3): nPd = rs(4)

if nOrg <> cOrg then ' new org
response.write "<p>Organization:" & nOrg
cOrg = nOrg
end if

if nFund <> cFund then ' new fund
response.write "<br>Fund:" & nFund
cFund = nFund
end if

if nProg <> cProg then
response.write "<br>Program:" & nProg
cProg = nProg
end if

response.write "<br>" & nAcc & ":" & nPd

rs.movenext
loop
%>

Are your tables really named by year? This is horrible design, you really
should have ONE table and have a column for year. You're really messing up
the whole idea of relational design and entity modeling...
 
A

Aaron [SQL Server MVP]

Well, there's a little bit of logic to fit here, e.g. if you have two orgs
with the same program or two programs with the same account, etc. You can
solve that by setting children to "" whenever you hit a new tier, e.g.

<%
sql = "SELECT Organization, Fund, Program, Account, PdAmount" & _
"FROM " & TheYear & _
" ORDER BY Organization, Fund, Program, Account"

cOrg = "": cFund = "": cProg = "": cAcc = ""

set rs = conn.execute(sql)

do while not rs.eof
nOrg = rs(0): nFund = rs(1): nProg = rs(2)
nAcc = rs(3): nPd = rs(4)

if nOrg <> cOrg then ' new org
response.write "<p>Organization:" & nOrg
cOrg = nOrg: cFund="": cProg=""
end if

if nFund <> cFund then ' new fund
response.write "<br>Fund:" & nFund
cFund = nFund: cProg=""
end if

if nProg <> cProg then
response.write "<br>Program:" & nProg
cProg = nProg
end if

response.write "<br>" & nAcc & ":" & nPd

rs.movenext
loop
%>
 
A

Abby Lee

Aaron said:
Well, there's a little bit of logic to fit here, e.g. if you have two orgs
with the same program or two programs with the same account, etc. You can
solve that by setting children to "" whenever you hit a new tier, e.g.

<%
sql = "SELECT Organization, Fund, Program, Account, PdAmount" & _
"FROM " & TheYear & _
" ORDER BY Organization, Fund, Program, Account"

cOrg = "": cFund = "": cProg = "": cAcc = ""

set rs = conn.execute(sql)

do while not rs.eof
nOrg = rs(0): nFund = rs(1): nProg = rs(2)
nAcc = rs(3): nPd = rs(4)

if nOrg <> cOrg then ' new org
response.write "<p>Organization:" & nOrg
cOrg = nOrg: cFund="": cProg=""
end if

if nFund <> cFund then ' new fund
response.write "<br>Fund:" & nFund
cFund = nFund: cProg=""
end if

if nProg <> cProg then
response.write "<br>Program:" & nProg
cProg = nProg
end if

response.write "<br>" & nAcc & ":" & nPd

rs.movenext
loop
%>

I get an Object Required error when I reach the line:
set rs = conn.execute(sql)

Do I needt to make a change to my script that connects to my db?
Set connect = Server.CreateObject("ADODB.Connection")
Set rs = Server.CreateOBject("ADODB.Recordset")
connect.ConnectionString = _
"Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=" & sDataSource
connect.Open
 
A

Aaron [SQL Server MVP]

I get an Object Required error when I reach the line:
set rs = conn.execute(sql)

Do I needt to make a change to my script that connects to my db?
Set connect = Server.CreateObject("ADODB.Connection")
Set rs = Server.CreateOBject("ADODB.Recordset")
connect.ConnectionString = _
"Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=" & sDataSource
connect.Open

Well, do you want to use the name conn, or the name connect? Pick one.

set conn = CreateObject("ADODB.Connection")
connStr = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=" & sDataSource
conn.open connStr
....
set rs = conn.execute(sql)

or

set connect = CreateObject("ADODB.Connection")
connectStr = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=" & sDataSource
connect.open connStr
....
set rs = connect.execute(sql)

I think you'll find that the most common convention is to use the word conn
(or oConn) as opposed to connect, but you could call it baker or airplane or
bobizumi if you wanted to... just stick to one name.
 
A

Abby Lee

I used this code...which worked...but gave me strange output.
Instead of a list of Accounts with totals I got pages of this...
Organization:Organization
Fund:Fund
Program:program
Account:MonthPD
Account:MonthPD
Account:MonthPD
Account:MonthPD
Account:MonthPD

<%
sql = "SELECT 'Organization','Fund','Program','Account','MonthPD'" & _
"FROM AllExpenses2004 " & _
" WHERE MonthPD = '0604'" & _
" ORDER BY 'Organization', 'Fund', 'Program', 'Account'"

cOrg = "": cFund = "": cProg = "": cAcc = ""

set rs = connect.execute(sql)


do while not rs.eof
nOrg = rs(0): nFund = rs(1): nProg = rs(2)
nAcc = rs(3): nPd = rs(4)

if nOrg <> cOrg then ' new org
response.write "<p>Organization:" & nOrg
cOrg = nOrg: cFund="": cProg=""
end if

if nFund <> cFund then ' new fund
response.write "<br>Fund:" & nFund
cFund = nFund: cProg=""
end if

if nProg <> cProg then
response.write "<br>Program:" & nProg
cProg = nProg
end if

response.write "<br>" & nAcc & ":" & nPd

rs.movenext
loop
%>
 
A

Aaron [SQL Server MVP]

Why did you change SELECT Organization, ... to SELECT 'Organization', ...

???
 
A

Abby Lee

When I use SELECT Organization,
I get the error message:
Error Type:
Microsoft JET Database Engine (0x80040E14)
Syntax error (missing operator) in query expression 'OrganizationFROM
AllExpenses2004 WHERE MonthPD = '0604' ORDER BY 'Organization''.

But the SELECT 'Organization', has its own problems.

I finally did this:
SELECT *
and changed this...to fit my db:
nOrg = rs(3): nFund = rs(2): nProg = rs(5)
nAcc = rs(4): nPd = rs(19)

I hate having to grabb all the extra information but this works.
Thanks.
 
B

Bob Lehmann

You need a space in between Organization and FROM.

Bob Lehmann

Abby Lee said:
When I use SELECT Organization,
I get the error message:
Error Type:
Microsoft JET Database Engine (0x80040E14)
Syntax error (missing operator) in query expression 'OrganizationFROM
AllExpenses2004 WHERE MonthPD = '0604' ORDER BY 'Organization''.

But the SELECT 'Organization', has its own problems.

I finally did this:
SELECT *
and changed this...to fit my db:
nOrg = rs(3): nFund = rs(2): nProg = rs(5)
nAcc = rs(4): nPd = rs(19)

I hate having to grabb all the extra information but this works.
Thanks.

"Aaron [SQL Server MVP]" <[email protected]> wrote in message
Why did you change SELECT Organization, ... to SELECT 'Organization', ....

???
 
A

Aaron [SQL Server MVP]

Yep, if you response.write(sql) -- pretty common and trivial debugging
technique -- you'll see that you're missing a space between the column and
the keyword FROM.

--
http://www.aspfaq.com/
(Reverse address to reply.)




Abby Lee said:
When I use SELECT Organization,
I get the error message:
Error Type:
Microsoft JET Database Engine (0x80040E14)
Syntax error (missing operator) in query expression 'OrganizationFROM
AllExpenses2004 WHERE MonthPD = '0604' ORDER BY 'Organization''.

But the SELECT 'Organization', has its own problems.

I finally did this:
SELECT *
and changed this...to fit my db:
nOrg = rs(3): nFund = rs(2): nProg = rs(5)
nAcc = rs(4): nPd = rs(19)

I hate having to grabb all the extra information but this works.
Thanks.

"Aaron [SQL Server MVP]" <[email protected]> wrote in message
Why did you change SELECT Organization, ... to SELECT 'Organization', ....

???
 

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

Members online

Forum statistics

Threads
473,994
Messages
2,570,223
Members
46,810
Latest member
Kassie0918

Latest Threads

Top