Help with special query, confused

  • Thread starter Thread starter Angela
  • Start date Start date
A

Angela

Hello,

I have two tables.

Table1:
Date/Time Number Product
12/03/2009 7870055 PLANA
12/05/2009 7870055 PLANA

Table2:
Date/Time Number Product
14/04/2009 7870055 Done


Well as one can see, the number is common in both tables.
I would like to return a query with following result.

Result:
Date/Time Number Product
12/05/2009 7870055 PLANA

My guess is the date column has to play an important role here but
how, that is confusing.

Thanks.
 
Angela,

What do the two tables represent? Are there any other fields involved? The
schema of the tables is identical, so it's not clear from your example why
you even have two tables. Your query result looks like it came from Table 1
only, but you didn't list what the query was. Also, what field is unique in
each table? Typically, that will be the field that you use to link the
tables.

Could you post the full schema for both tables and provide a little more
detail about what you are trying to query?
 
Hello Steve,

The actual scheme is around 50 columns.

The unique column is product.

First comes table1, The date suggests the order.
It is not logical to have a "Done" for a date in table2 that comes
after the date in table 1

April comes after March.. so line of April should match with March but
April is incorrect after the month of May.. so in query result I
should hopefully the line of May.

For the sake of example, I have given different dates. Date for "Done"
can be same for date of "plan".

This way we would be able to identify for which plans, we did not have
a done line.

Infact we would have two queries.

One to show the matchs & one to show the left overs.
 
Angela,

I would need to see the columns in both tables to understand what the tables
are for. If Table1 is for listing your products, then I would name the table
Products. If Table 2 is for product status, then maybe you could call it
Status.

In your example, the Product column does not contain unique values, so can't
be used as a primary key for queries. I also do not understand why you would
have the same Product listed with different date values. What is this table
for? I think you have some schema problems to resolve before you can fix
your queries.
 
Hey Steve,

Thanks for writing.

Well the unique identifier is a problem.

Just a thought, is it possible to create a query with table1 with an
additional column that would add a count to the occurance of Number
column.

Like the query will look like

Date/Time Number Product Occurance
12/03/2009 7870055 PLANA 1
12/05/2009 7870055 PLANA 2

and then match it with table2 with similar treatment

Date/Time Number Product Occurance
14/04/2009 7870055 Done 1

Well you can name anything to the tables since its an example.

First table is for plan.
Second table is the status.
 
Angela said:
Hello,

I have two tables.

Table1:
Date/Time Number Product
12/03/2009 7870055 PLANA
12/05/2009 7870055 PLANA

Table2:
Date/Time Number Product
14/04/2009 7870055 Done


Well as one can see, the number is common in both tables.
I would like to return a query with following result.

Result:
Date/Time Number Product
12/05/2009 7870055 PLANA

My guess is the date column has to play an important role here but
how, that is confusing.

Thanks.
 
Angela,

Without seeing the entire schema, I can't really suggest how to fix this.
With relational databases, every table must have a primary key that is
unique for each record. To link a secondary table to the first, it must
contain a foreign key which matches the primary key in the first table.
There can be multiple instances of the foreign key in the secondary table.

Have a look at this example:
http://www.geekgirls.com/databases_from_scratch_3.htm It gives a fairly high
level overview of some of the problems encountered when designing a
relational database.
 
Maybe this is what you want --
SELECT Table1.YourDate, Table1.Number, Table1.Product
FROM Table1 LEFT JOIN Table2 ON Table1.Number = Table2.Number
WHERE Table1.YourDate >= Table2.YourDate AND Table2.Product = "Done"
ORDER BY Table1.YourDate, Table1.Number, Table1.Product;
 
Back
Top