473,387 Members | 1,891 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,387 software developers and data experts.

Joining tables

Hi i am newbie here and to SQL and was hoping somebody could help me on this

I have two tables Bookings and Booking_History as below

BOOKINGS
------------------------------------------
| id | guest_name | location |
------------------------------------------
| 1 | person1 | spain |
| 2 | person2 | germany |
| 3 | person3 | italy |
-------------------------------------------

BOOKINGS_HISTORY
----------------------------------------
|id | book_id | action | total |
----------------------------------------
| 1 | 1 | confirmed | 200 |
| 2 | 1 | extra person | 300 |
| 3 | 2 | confirmed | 250 |
| 4 | 1 | minus person | 200 |
| 5 | 3 | confirmed | 300 |
| 6 | 3 | cancelled | 0 |
| 7 | 2 | extra bags | 300 |
----------------------------------------

The tables are more complicated but it gives the basic outline.

What i need to do is produce a table like below where it shows each
individual booking with the last action that was performed on it

-----------------------------------------------------
| id | guest_name | location | total |
------------------------------------------------------
| 1 | person1 | spain | 200 |
| 2 | person2 | germany | 0 |
| 3 | person3 | italy | 300 |
------------------------------------------------------

I know how to join the tables but do not no how to do a query based join.
Any help would be gratefully appreciated.

Steve
Feb 28 '07 #1
2 1032
almaz
168 Expert 100+
What action do you treat as "last"? With the biggest ID? If yes, try this solution:
Expand|Select|Wrap|Line Numbers
  1. select B.*, BH.* 
  2. from
  3.     BOOKINGS B 
  4. inner join BOOKINGS_HISTORY BH 
  5.     on B.id = BH.book_id
  6. inner join 
  7.     (
  8.         select book_id, id = max(id) 
  9.         from BOOKINGS_HISTORY
  10.         group by book_id
  11.     ) BH_LAST
  12.     on BH.id = BH_LAST.id and BH.book_id = BH_LAST.book_id 
  13.         and B.id = BH_LAST.book_id 
P.S. Note the last condition (B.id = BH_LAST.book_id). It duplicates condition on previous join, but allows SQL Server to choose the best join strategy.
Mar 1 '07 #2
Fantastic, after some tweeks here and there it worked a treat! I'm gonna spend some time looking at it now to make sure I totally understand it, I'm not gonna learn otherwise!

Many Thanks almaz
Mar 1 '07 #3

Sign in to post your reply or Sign up for a free account.

Similar topics

4
by: Job Lot | last post by:
Is there anyway of Joining two or more DataTable with similar structure? I have three DataTables with following structures Data, AmountB/F, Repayments, InterestCharged and AmountC/F i want...
2
by: James | last post by:
Can anyone please shed some light on the following... I have a framework that uses dynamically created tables, named using an incremental "attribute set ID", as follows: attrdata_1 attrdata_2...
3
by: james | last post by:
Hi, I would like to get all the records from 9 tables that have the same field value in one field (it is a unique field)that is shared by all the tables. Would this method of joining work: ...
1
by: Brian | last post by:
I need help joining info from two tables. Table1 and Table 2 have the same fields(Node,Card,Slot,Facility,Sub-Port,Channel,Group,Cic) Group is text, rest are number. Table 1 contains records for...
2
by: Coquette | last post by:
Hi all. I'm new here. I wanted to ask your opinion about *joining two tables* from *two different database* together. Is *that* possible? My project requires me to join identical tables from...
10
by: Captain Nemo | last post by:
Hi I'm working on an ASP project where the clients want to be able to effectively perform SELECT queries joining tables from two different databases (located on the same SQL-Server). Does...
3
by: Reader | last post by:
Hello all, I am joining two tables in a query and the output should be all those records where two fields in table1 match two corresponding fields in table2. I joined the tables using both...
2
by: nkechifesie | last post by:
I have created 9 tables in access via visdata and need to create another table joining all these tables. I have used the query in visdata to do this but it gives me an outrageous view. I have entered...
4
by: Rnt6872 | last post by:
Table A Table B BOL# B_BOL# Chargeback# Hi All, I have been struggling with this for...
2
by: Supermansteel | last post by:
I am joining these 2 tables together in Access 2003 and can't figure out the exact way of writing this script......Can anyone help? I have the following SQL: SELECT...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: aa123db | last post by:
Variable and constants Use var or let for variables and const fror constants. Var foo ='bar'; Let foo ='bar';const baz ='bar'; Functions function $name$ ($parameters$) { } ...
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.