Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

Sql question

Posted on 2015-02-04
12
Medium Priority
?
147 Views
Last Modified: 2015-02-05
Hi Experts,

I have the following two queries that would like to total the quantity of the records in the table, and for some reason I am missing some records.

Can someone explain where is the hole?

query1
SELECT dbo_TimeSheet.Day, dbo_TimeSheet.TimeEntered, Format([TimeEntered],"mm/dd/yy") AS Expr1
FROM dbo_TimeSheet WHERE (((dbo_TimeSheet.Day) Is Not Null) AND ((dbo_TimeSheet.TimeEntered) Is Not Null) AND ((Format([TimeEntered],"mm/dd/yy"))<>CStr([day])));

Open in new window

query2
SELECT dbo_TimeSheet.Day, dbo_TimeSheet.TimeEntered, Format([TimeEntered],"mm/dd/yy") AS Expr1
FROM dbo_TimeSheet WHERE (((dbo_TimeSheet.Day) Is Not Null) AND ((dbo_TimeSheet.TimeEntered) Is Not Null) AND ((Format([TimeEntered],"mm/dd/yy"))=CStr([day])));[/

Open in new window


P.S. there are only few records with no Day field entered or no TimeEntered, not enough to justify the discrepancy.
0
Comment
Question by:bfuchs
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
  • 2
  • +3
12 Comments
 
LVL 66

Expert Comment

by:Jim Horn
ID: 40590323
>total the quantity of the records in the table
Total ... what exactly?  Sum of days, sum of time entered, ...
Both queries together, each one separately...
0
 
LVL 4

Author Comment

by:bfuchs
ID: 40590327
Hi,
Total quantity of records from both queries together should equal the quantity of records in the table.
0
 
LVL 66

Expert Comment

by:Jim Horn
ID: 40590332
Define 'quantity', by the column name, and the aggregate you wish to perform (SUM, COUNT, etc.)
0
What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

 
LVL 4

Author Comment

by:bfuchs
ID: 40590338
I Have a table containing 2 columns

Day where date is entered
TimeEntered where date+time is entered

would like to see all those records that day column has a different date than the date portion in TimeEntered field.

This is the reason I am running those queries.

In order to ensure I am getting the correct results, I want to sum all those records that dates are the same with those that they are not the same, and get the total qty of records equal to what I have in the table.
0
 
LVL 1

Expert Comment

by:lalitgada
ID: 40590362
hi,

Kindly check date entered in the table is correct or not.
0
 
LVL 49

Accepted Solution

by:
PortletPaul earned 1000 total points
ID: 40590374
I would suggest using DATEDIFF(interval, date1, date2) that returns an integer of the chosen interval between two dates instead of relying on character representations of dates. Here the interval of day ("d") can be used as you are only concerned with the date and not time.

You could check the numbers like this:
SELECT
      COUNT(*) AS TOT
    , SUM(IIF(DATEDIFF("d", [day], [TimeEntered]) = 0,1,0)) AS EQL
    , SUM(IIF(DATEDIFF("d", [day], [TimeEntered]) <> 0,1,0)) AS UNEQL
FROM dbo_TimeSheet
WHERE (dbo_TimeSheet.Day) IS NOT NULL
      AND (dbo_TimeSheet.TimeEntered) IS NOT NULL)
;

Open in new window


and get the rows like this
SELECT
      dbo_TimeSheet.Day
    , dbo_TimeSheet.TimeEntered
    , Format([TimeEntered], "mm/dd/yy") AS EXPR1
FROM dbo_TimeSheet
WHERE DATEDIFF("d", [day], [TimeEntered]) <> 0
;

Open in new window


SELECT
      dbo_TimeSheet.Day
    , dbo_TimeSheet.TimeEntered
    , Format([TimeEntered], "mm/dd/yy") AS EXPR1
FROM dbo_TimeSheet
WHERE DATEDIFF("d", [day], [TimeEntered]) = 0
;

Open in new window


Note: if either  [day] or [TimeEntered] are NULL then datediff() cannot return a value so only those rows with values in both fields can meet the  <> 0 or = 0 criteria.
0
 
LVL 51

Assisted Solution

by:Gustav Brock
Gustav Brock earned 1000 total points
ID: 40590493
As you want to check the total count of records, you would have to count those with Nulls as well.

You could have one single query:

Select
    dbo_TimeSheet.Day,
    dbo_TimeSheet.TimeEntered,
    DateValue([TimeEntered] AS DayOfTimeEntered,
    dbo_TimeSheet.Day Is Null Or dbo_TimeSheet.TimeEntered Is Null As NullDate,
    DateDiff("d", Nz(dbo_TimeSheet.Day, #00:00#), Nz(dbo_TimeSheet.TimeEntered, #00:00#)) = 0 As DateMatch
From
    dbo_TimeSheet

Now you can use this directly and filter as you wish, or you can use it as the source for other queries that filter the output.

/gustav
0
 
LVL 52

Expert Comment

by:Vitor Montalvão
ID: 40590538
How many records returns each query? And how many records was you expecting to be returned?
Without some sample data it's hard for us to try to guess.
0
 
LVL 4

Author Comment

by:bfuchs
ID: 40592129
@PortletPaul,
In middle of testing yours..

@Gustav,
See attached.
untitled.bmp
0
 
LVL 51

Expert Comment

by:Gustav Brock
ID: 40592265
It is:

   DateValue([TimeEntered]) AS DayOfTimeEntered,

/gustav
0
 
LVL 4

Author Closing Comment

by:bfuchs
ID: 40592301
Working well, thank you!
0
 
LVL 51

Expert Comment

by:Gustav Brock
ID: 40593018
You are welcome!

/gustav
0

Featured Post

Windows Server 2016: All you need to know

Learn about Hyper-V features that increase functionality and usability of Microsoft Windows Server 2016. Also, throughout this eBook, you’ll find some basic PowerShell examples that will help you leverage the scripts in your environments!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Microsoft Access is a place to store data within tables and represent this stored data using multiple database objects such as in form of macros, forms, reports, etc. After a MS Access database is created there is need to improve the performance and…
This post looks at MongoDB and MySQL, and covers high-level MongoDB strengths, weaknesses, features, and uses from the perspective of an SQL user.
In Microsoft Access, learn how to use Dlookup and other domain aggregate functions and one method of specifying a string value within a string. Specify the first argument, which is the expression to be returned: Specify the second argument, which …
Viewers will learn how the fundamental information of how to create a table.

722 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question