Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations strongm on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Formatting SQL SELECT using SUMs returns an error 2

Status
Not open for further replies.

JeffreyLSmith

IS-IT--Management
Feb 20, 2001
2
JP
I've added several sum functions to the query string which is "ok" per the Data Env. designer, but VB returns an error upon execution. The error appears to be within a previously working section of the query, ala before the sum functions were added. Here is the query:

"SELECT SUM(Mon) AS MonHrs, SUM(Tue) AS TueHrs,
SUM(Wed) AS WedHrs, SUM(Thu) AS ThuHrs,
SUM(Fri) AS FriHrs, SUM(Sat) AS SatHrs,
SUM(Sun) AS SunHrs,
Project, Task,
Mon, Tue, Wed, Thu, Fri, Sat, Sun,
Purpose, Issue, WeekEnding,
EmployeeName, ID
FROM tblTimeEntries
WHERE WeekEnding = 'sWeekEnding' AND
EmployeeName = 'sCurrentUser'"

It now bombs with this error:

"you tried to execute a query which does not include the specified expression 'Project' as part of an aggregate function"

????? Again, the DE designer checked the syntax with no problems but Visual Basic is dumping? Any help?
 
In the said query, you are trying to use an aggregate function. So for all the other fields that you are not using the aggregate function, you will need to use the Group by clause.
So it will look something like :
SELECT SUM(Mon) AS MonHrs, SUM(Tue) AS TueHrs,
SUM(Wed) AS WedHrs, SUM(Thu) AS ThuHrs,
SUM(Fri) AS FriHrs, SUM(Sat) AS SatHrs,
SUM(Sun) AS SunHrs,
Project, Task,
Mon, Tue, Wed, Thu, Fri, Sat, Sun,
Purpose, Issue, WeekEnding,
EmployeeName, ID
FROM tblTimeEntries
WHERE WeekEnding = 'sWeekEnding' AND
EmployeeName = 'sCurrentUser'
Group by Project, Task, Mon....... and so on...
You will need to include all the fields missing from the aggregate function.
 
Thanks for the info Antzz... I have a second question relative to the SUM function. Is the resulting field as described by the AS parameter a summation of all the records in the SUM(FIELD) field? Hope this makes sense...

Thanks.
 
Jeffrey,

The Sum function returns a sum of all the values in each record for that field. It does not return the number of records. To return that you would use the Count function. For you to use Sum, the field must be a numeric field. Are Mon, Tues, ..., numeric fields? If not, maybe you are looking for a count.

I'm not sure if that helps. If not, try explaining what the datatype is of the fields you are selecting and what you need to get out of the query.

Steve
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top