Solved

How to eliminate duplicate rows in oracle sql

Posted on 2011-09-15
8
383 Views
Last Modified: 2013-12-19
I know this is stupid question to ask but just giving a try if any one can help me.


I have two tables A & B

Table A Columns
-------------------

ID           AMOUNT
1               100
1               200
1               300
1               400
1               500

Table B columns
--------------------

ID              NO
1               ABC
1               DEF
1               GHI
1               JKL
1               MNO


When I join both the tables I get 5*5 = 25 rows

Is there any way I can get 5 records when I join both the tables with ID as Join ?







0
Comment
Question by:VenkatBunny
[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
8 Comments
 
LVL 77

Accepted Solution

by:
slightwv (䄆 Netminder) earned 125 total points
ID: 36546352
Add a where clause?

Select t1.id, amount, no
From tableA t1, tableB t2
Where t1.id=t2.I'd;
0
 

Author Comment

by:VenkatBunny
ID: 36546381
I join with ID I still get 25 rows
0
 
LVL 77

Expert Comment

by:slightwv (䄆 Netminder)
ID: 36546408
OH, I see it now.

There really aren't duplicates.

How do you relate what amount goes with what NO?

Does 100 go with ABC or MNO?
0
Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

 
LVL 38

Expert Comment

by:Gerwin Jansen, EE MVE
ID: 36546419
How should your 5 row output look like?
0
 
LVL 77

Expert Comment

by:slightwv (䄆 Netminder)
ID: 36546453
You can create an arbitrary join column but there you need to decide on what amount goes with what NO.

The code below produces:


        ID     AMOUNT N
---------- ---------- -
         1        100 a
         1        200 b
         1        300 c
         1        400 d
         1        500 e
drop table tab1 purge;
create table tab1(id number, amount number);

drop table tab2 purge;
create table tab2(id number, no char(1));

insert into tab1 values(1,100);
insert into tab1 values(1,200);
insert into tab1 values(1,300);
insert into tab1 values(1,400);
insert into tab1 values(1,500);

insert into tab2 values(1,'a');
insert into tab2 values(1,'b');
insert into tab2 values(1,'c');
insert into tab2 values(1,'d');
insert into tab2 values(1,'e');
commit;

select t1.id, t1.amount, t2.no
from
(select id, amount, row_number() over(order by amount) t1_rownum from tab1) t1,
(select id, no, row_number() over(order by no) t2_rownum from tab2) t2
where t1.id=t2.id and t1.t1_rownum = t2.t2_rownum;

Open in new window

0
 
LVL 7

Expert Comment

by:Piloute
ID: 36550196
0
 
LVL 77

Expert Comment

by:slightwv (䄆 Netminder)
ID: 36550321
Piloute,

Isn't that basically what I posted?
0
 
LVL 7

Expert Comment

by:Piloute
ID: 36891993
Humm,

Yup ! Looks similar.

What I want to point out here is that VenkatBunny probably didn't search for the problem before posting a question...

Cheers,
P
0

Featured Post

Enroll in June's Course of the Month

June’s Course of the Month is now available! Experts Exchange’s Premium Members, Team Accounts, and Qualified Experts have access to a complimentary course each month as part of their membership—an extra way to sharpen your skills and increase training.

Question has a verified solution.

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

Why doesn't the Oracle optimizer use my index? Querying too much data Most Oracle developers know that an index is useful when you can use it to restrict your result set to a small number of the total rows in a table. So, the obvious side…
Working with Network Access Control Lists in Oracle 11g (part 2) Part 1: http://www.e-e.com/A_8429.html Previously, I introduced the basics of network ACL's including how to create, delete and modify entries to allow and deny access.  For many…
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
Via a live example, show how to restore a database from backup after a simulated disk failure using RMAN.

724 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