Brilliant SQL Interview Question | Solve it without using CTE, Sub Query, Window functions

Поділитися
Вставка
  • Опубліковано 12 січ 2025

КОМЕНТАРІ • 148

  • @anshumansrivastava2801
    @anshumansrivastava2801 2 роки тому +4

    Hello Ankit,
    Here is my approach.
    select o.* from int_orders o left join int_orders o1
    on o.salesperson_id=o1.salesperson_id
    and o.amount

  • @meghnasoni
    @meghnasoni Рік тому +1

    Great video. Self joins are so powerful yet many people don't know enough about them. Thanks for the video Ankit.

  • @rajudasari8482
    @rajudasari8482 2 роки тому +5

    wow, amazed again. Ankit could you please make a video on how to insert data from one table A into table B using SQL stored procedure, the procedure should be dynamic whenever we do any DML operations in table A, table B has to be updated the same as table A.

  • @gagansingh3481
    @gagansingh3481 2 роки тому +1

    Your every questions are awesome ankit , I start watching & practing 5 queries each day .....

  • @Howto-ty4ru
    @Howto-ty4ru 2 роки тому +11

    For those who are having issue with creation of table and insertion of data:
    CREATE TABLE int_orders(
    order_number int NOT NULL,
    order_date date NOT NULL,
    cust_id int NOT NULL,
    salesperson_id int NOT NULL,
    amount float NOT NULL
    );
    INSERT INTO int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (30, CAST('1995-07-14' AS Date), 9, 1, 460);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (10, CAST('1996-08-02' AS Date), 4, 2, 540);
    INSERT INTO int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (40, CAST('1998-01-29' AS Date), 7, 2, 2400);
    INSERT INTO int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (50, CAST('1998-02-03' AS Date), 6, 7, 600);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (60, CAST('1998-03-02' AS Date), 6, 7, 720);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (70, CAST('1998-05-06' AS Date), 9, 7, 150);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (20, CAST('1999-01-30' AS Date), 4, 8, 1800);

  • @archis0605
    @archis0605 Рік тому

    Very unique like question. It's Like "SONE PE SUHAGAA".

  • @Alexpudow
    @Alexpudow 10 місяців тому

    Great video to understand a self join! But I think it doesn't have anything in common with real tasks. I mean if we have one million order rows it will be really complicated to use this approach. And I most likely will choose sub query or window function.
    Anyway thanks a lot, Ankit!

  • @exanode
    @exanode 6 місяців тому

    Awesome. Learnt something new about something so obvious.

  • @mohit231
    @mohit231 2 роки тому

    Wow, I watch your videos and learn something new

  • @akashanand1384
    @akashanand1384 2 роки тому +2

    Hi Ankit,
    Isn't it possible to simply just take group by and max on amount:
    Select order_number,date,ID,max(amount)
    From
    Group by 1,2,3 order by 3:

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      You will get all orders in output

    • @rockstaraishwary
      @rockstaraishwary 9 місяців тому

      Yes. I alsu used that only. But as Ankit said, it resulted in all order ids along with max amount. That is unnecessary repeatation in data.

  • @shubhankartiwari876
    @shubhankartiwari876 2 роки тому +1

    Superb & Outstanding CONCEPT.
    I WOULD LIKE TO KNOW --->
    HOW CAN WE DO THE ROW WISE MATCHING
    MEANS COMPARE FIRST ROW WITH Its BELOW ROWS.

  • @AJOnline_
    @AJOnline_ Рік тому

    Without using join clause. Much simpler. A lesser known trick in SQL.
    select * from int_orders i1
    where amount =
    (select max(amount) from int_orders i2 where i1.salesperson_id = i2.salesperson_id)

    • @Tusharchitrakar
      @Tusharchitrakar Рік тому +1

      this is pretty common and its not less known. It's a sub query and its not allowed as per the problem statement.

  • @manjunathareddycheruku7482
    @manjunathareddycheruku7482 2 роки тому

    Very usefull video thanks sharing for your time

  • @piyushjoshi3910
    @piyushjoshi3910 2 місяці тому

    my solution-
    select s.* from int_orders as s join(
    select salesPerson_id,max(amount) as max_amount from int_orders group by salesperson_id) as b on s.amount = b.max_amount

  • @RaviTheVlogger
    @RaviTheVlogger 2 роки тому

    Good. We can use window function aslo to get the desired result.

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      You can not use as per question. Otherwise question is simple 😃

  • @AjayYadav-gd8ys
    @AjayYadav-gd8ys Рік тому

    more simpler approach will joining two tables on a.salesperson_id = b.salesperson_id and b.amount> a.amount where b.amount is null
    select a.* from int_orders a
    left join int_orders b
    on a.salesperson_id = b.salesperson_id and b.amount> a.amount
    where b.amount is null ;

  • @amitkumar-ip6yv
    @amitkumar-ip6yv 2 роки тому +1

    thanks Ankit..good question

  • @SuperMohit95
    @SuperMohit95 2 роки тому

    Beautiful solution!!

  • @EL_News
    @EL_News 2 роки тому +1

    anki bhai why we cant use this below query ?
    select order_number, order_date,cust_id, salesperson_id , max(amount)
    from int_orders
    group by salesperson_id ;

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      We need full order details

    • @AmanRaj-uf7wx
      @AmanRaj-uf7wx Рік тому

      @@ankitbansal6 we are getting the desired out also what will you with full order details.

  • @swamivivekananda-cyclonicm8781
    @swamivivekananda-cyclonicm8781 2 роки тому

    Comgratulations on promotion :)

  • @nehajain9081
    @nehajain9081 3 місяці тому

    y have u used left join instead of inner join?@Ankit

  • @shwetasingh6576
    @shwetasingh6576 7 місяців тому

    select order_number,order_date,cust_id,salesperson_id,max(amount) from int_orders
    group by salesperson_id----is this works?

  • @RamanGangwani
    @RamanGangwani Рік тому

    select * from int_orders
    where amount in
    (select max(amount) from int_orders
    group by salesperson_id)
    order by order_number

  • @arpanscreations6954
    @arpanscreations6954 6 місяців тому

    This is brilliant.

  • @BengaluruGuy08
    @BengaluruGuy08 2 роки тому

    Great explanation....

  • @suvratrai8873
    @suvratrai8873 Рік тому +1

    The result should be the same if we use inner join instead of left join, right?

  • @suneelsunkari4354
    @suneelsunkari4354 2 роки тому +1

    Sir,
    could you please let me know if we can join main table with below query on brackets based on salesperson_id
    select salesperson_id,max(amount) from init_orders group by salesperson_id
    after joining can we use normal filter to filter at row level like amount>= max_amount.
    This was your earlier concept where we find minimum customer joining date using cte but this is join where we enclose above query and give alias
    Kindly let me know if this is possible.

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      This works but question is you can't use sub query or temp table

  • @PR-qj3ry
    @PR-qj3ry 2 роки тому

    Very nicely explained Ankit 👍🏻

  • @shubhamprasad1200
    @shubhamprasad1200 Рік тому

    Hey Ankit , did this question using join with a different method. Will this work fine? Please check
    Select a.*
    From(select order_number as order_number_a, order_date as order_date_a, cust_id as cust_id_a,salesperson_id as salesperson_id_a, amount as amount_a
    from [int_orders]) as a
    inner join
    (select salesperson_id,MAX(amount) as amount
    from [int_orders]
    group by salesperson_id) as b
    on a.salesperson_id_a=b.salesperson_id and a.amount_a=b.amount

  • @pinaakgoel2937
    @pinaakgoel2937 2 роки тому

    Hi Ankit I did via following method, let me know if it is acceptable :-
    select t1.* from int_orders as t1
    inner join (select salesperson_id, max(amount) as max_amnt
    from int_orders group by salesperson_id) t2
    on t1.salerperson_id = t2.salesperson_id and t1.amount = t2.max_amnt

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      With sub query this question is easy. Challenge is doing without subquery or cte or window functions

  • @pratikpednekar75
    @pratikpednekar75 2 роки тому

    Hi Ankit,
    Here is my solution with using only join:-
    select o1.*
    from int_orders o1
    left outer join int_orders o2
    on o1.amount

    • @2412_Sujoy_Das
      @2412_Sujoy_Das Рік тому

      Simple and Brilliant.......... Pratik!!
      Thanks for sharing

  • @namansharma4038
    @namansharma4038 Рік тому

    We could have used the group by clause also

  • @mohitupadhayay1439
    @mohitupadhayay1439 2 роки тому +1

    Ankit bhai. Shouldn't there be a Where clause used instead of HAVING?
    I think HAVING will work only after the GROUPBY has done it's work. In that case the results would be different?
    Please help.

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      You can't use aggregation in where

    • @mohitupadhayay1439
      @mohitupadhayay1439 2 роки тому

      @@ankitbansal6 I understand that Ankit bhai. But in your video results Order 10 is not getting highlighted. Please check.

  • @anitadevi365
    @anitadevi365 2 роки тому

    Nice concept.
    Can you solve this as well.
    Time status
    10.01 on
    10.02 on
    10.03 on
    10.04 off
    10.07 on
    10.08 on
    10.09 off
    o/p:
    login logout count
    10.01 10.04 3
    10.07 10.09 2

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      Thank you 😊 will post a video soon

  • @PriyaYadav-jh5wj
    @PriyaYadav-jh5wj 2 роки тому

    Can be simply done using this way:
    with max_sale as (
    select salesperson_id, max(amount) as amt
    from int_orders)
    select a.order_number,a.order_date, a.cust_id,
    b.salesperson_id, b.amt
    from int_orders a
    inner join
    max_sale b
    on b.salesperson_id = a.salesperson
    AND b.amt = a.amount;

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      It is mentioned that you should not use CTE

    • @PriyaYadav-jh5wj
      @PriyaYadav-jh5wj 2 роки тому +1

      @@ankitbansal6 oh noo..oops, my bad !
      Yours is a great solution then :)

  • @adityaagrawal1731
    @adityaagrawal1731 2 роки тому +1

    ankit pls give a better DDL im getting error in creating a table

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      Sorry about it. I have updated it. Please try again.

  • @pandeyRaman
    @pandeyRaman 3 місяці тому

    why > is used only = is sufficient

  • @saimahendrapatnaik2847
    @saimahendrapatnaik2847 Рік тому

    Amazing...

  • @adharshsunny5154
    @adharshsunny5154 2 роки тому

    good work as always :)

  • @sid101invalorant9
    @sid101invalorant9 2 роки тому +1

    Hi Ankit,
    I tried the same problem with below query and got the same answer.
    select a.salesperson_id, max(b.amount)
    from [int_orders] a
    left join [int_orders] b
    on a.salesperson_id = b.salesperson_id
    group by a.salesperson_id;
    Would there be any problem in the result of this query if the data scenario changes?
    or will it work the same as shown in video

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      We need full order details for max amount. Not just sales person id ..

    • @tarunsaini110
      @tarunsaini110 Рік тому

      @@ankitbansal6 ONCE WE HAVE THE SALES PERSON ID AND AMOUNT WE CAN JOIN BASED N BOTH OF THOSE AND GET ALL VALUES

  • @namanmakkar1205
    @namanmakkar1205 2 роки тому

    Can you write the solution using CTE. I tried but not able to find out. I am new to SQL.
    with cte sales as select order_number,order_date,cust_id,salesperson_id,max(amount),rank() over(partition by salesperson_id order by order_number) as rn from orders;

    • @ankitachatterjee8769
      @ankitachatterjee8769 2 роки тому

      with cte as(select order_number,order_date,cust_id,salesperson_id,amount,count(1) over(partition by salesperson_id) as cnt,
      rank() over(partition by salesperson_id order by amount desc) as rn from int_orders)
      select order_number,order_date,cust_id,salesperson_id,amount
      from cte where rn=1 or cnt=1 order by order_number

  • @Lakshya-jz8mu
    @Lakshya-jz8mu 7 місяців тому

    select A.order_number,A.order_date,A.salesperson_id,A.amount
    from int_orders as A left join
    int_orders as B on A.salesperson_id = B.salesperson_id and A.amount < B.amount
    where B.amount is null

  • @abhay6276
    @abhay6276 8 місяців тому +1

    it is very hard to digest for me what you wrote 🙄🥺

  • @amrutaborse2163
    @amrutaborse2163 11 місяців тому

    select * from order234 a
    where 1 =(select count(distinct amount) from order234 b
    where a.amount

    • @rawat7203
      @rawat7203 4 місяці тому

      No subquery bro

  • @saurabhsoni1998
    @saurabhsoni1998 2 роки тому

    select a.order_number, a.order_date, a.cust_id, a.salesperson_id, a.amount
    from [dbo].[int_orders] a inner join [dbo].[int_orders] b
    on a.salesperson_id = b.salesperson_id
    group by a.order_number, a.order_date, a.cust_id, a.salesperson_id, a.amount
    having a.amount >= max(b.amount)

  • @vijaypalmanit
    @vijaypalmanit 2 роки тому

    Fantastic

  • @Guna_Learning2022
    @Guna_Learning2022 Рік тому

    select order_number,order_date,cust_id,a.salesperson_id,a.amount
    from int_orders a join
    (select salesperson_id,max(amount) as amount from int_orders
    group by salesperson_id) b
    on a.salesperson_id=b.salesperson_id and a.amount=b.amount
    Order by A.order_number

  • @adharshsunny2709
    @adharshsunny2709 2 роки тому

    Thanks man

  • @kalyankumar6159
    @kalyankumar6159 2 роки тому

    Hi ankit recently I faced an interview with Infosys. He asked me a question consider a arable has 10 records he asked me how will swap the 1 and 6 records in the table record : 1 have the value Infosys record 6 have the value google we must move the google to 1st place and Infosys to 6th place he asked me the query. Please do a video on this question

    • @shekharagarwal1004
      @shekharagarwal1004 2 дні тому

      You can assign some sequence number first and then swap the sequence number using if else . Post that -apply the update on top of the above flow
      -- took the above examples :
      select * , case when rnk=1 then 6
      when rnk=6 then 1
      else rnk end as new_rnk
      from (
      Select *, rank() over(order by order_date) as rnk from int_orders
      ) a
      order by new_rnk

  • @dipanjan93
    @dipanjan93 2 роки тому +1

    Can't we do it this way?
    Select a.order_number,
    a.order_date,
    a.cust_id,
    a.salesperson_id,
    b.amount
    from int_orders as a
    join
    (Select salesperson_id, max(amount) as amount from int_orders group by salesperson_id) as b
    on a.salesperson_id = b.salesperson_id and a.amount = b.amount
    order by a.order_number

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      As per problem sub query not allowed 😊

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      @UCrmVcaahqeugmWiyIvEeJGQ you are right. Just equal to should be good. Thanks for pointing out.

  • @chanduguttula25
    @chanduguttula25 2 роки тому

    select a.* from int_orders a
    left join (select max(amount) as max_amt,salesperson_id from int_orders group by salesperson_id) b ON
    a.salesperson_id=b.salesperson_id and a.amount=b.max_amt where b.max_amt in (select amount from int_orders)
    Is it correct sir?

  • @adityabaha
    @adityabaha 2 роки тому

    Super 👍

  • @innominatesoloist1597
    @innominatesoloist1597 2 роки тому

    thanks

  • @chandraprakash0211
    @chandraprakash0211 2 роки тому

    Can this work...
    Select order_number, order_date, cust_id, salesperson_id, max(amount) as amt
    From int_orders
    Group by 1,2,3,4

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      Nope. Order number will differ for multiple orders by a sales person

    • @chandraprakash0211
      @chandraprakash0211 2 роки тому

      @@ankitbansal6 yes, Thank you for the feedback

  • @sindhujajittuka9020
    @sindhujajittuka9020 Рік тому

    Unable to get with cte
    Iam new to sql
    Can anyone suggest best tutorial

  • @SudhirKumar-rl4wt
    @SudhirKumar-rl4wt 2 роки тому +1

    Awesome...my solution[provided MINUS is allowed] is a little lengthy :)

  • @mohitupadhayay1439
    @mohitupadhayay1439 2 роки тому

    Spot on stuff! Ankit bhai can you prepare videos where businesses need some specific KPIs or Reports based on SQL. It can be related to HR, Purchase, Sales and so on.
    Would be helpful! Thanks in Advance.

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      Thanks Mohit. If you have any use case let me know. I will prepare the video

  • @mohitupadhayay1439
    @mohitupadhayay1439 2 роки тому

    I tried doing this with ROW number . Here's my query:
    SELECT * , ROW_NUMBER() OVER(PARTITION BY salesperson_id, ORDER BY amount DESC) AS Ranking
    from int_orders;
    What is wrong with it?

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      Window functions now allowed 😊

    • @mohitupadhayay1439
      @mohitupadhayay1439 2 роки тому

      @@ankitbansal6 I just tried using it. That's why asking where's my fault?

    • @dileepn2479
      @dileepn2479 2 роки тому

      The rectified one
      select * from (SELECT * , ROW_NUMBER() OVER(PARTITION BY salesperson_id ORDER BY amount DESC) AS Ranking from int_orders)a where a.Ranking=1;
      this should be solution using window functions ( i do understand window functions to be excluded)

  • @rohitbande5758
    @rohitbande5758 Рік тому

    Can anyone please confirm whether below solution works for mentioned problem
    select a.*
    from
    int_orders a left join int_orders b
    on a.salesperson_id=b.salesperson_id and a.amount

  • @Datapassenger_prashant
    @Datapassenger_prashant 7 місяців тому

    --Solved it without using CTE, Sub Query, Window functions and without watching the video..
    will watch video after posting the solution to match the query..:D
    Select * from int_orders b
    where exists (
    select
    salesperson_id, max(a.amount) as larget_Value
    from int_orders a
    where b.salesperson_id = a.salesperson_id
    group by salesperson_id
    having max(a.amount) = b.amount
    )

    • @Datapassenger_prashant
      @Datapassenger_prashant 7 місяців тому

      I guess, I messed up.. after watching the video.. as there is where exists subquery.. my bad.. 😮‍💨

    • @Datapassenger_prashant
      @Datapassenger_prashant 7 місяців тому

      Corrected in next attempt:
      Select a.order_number, a.salesperson_id, a.amount from int_orders a
      inner join int_orders b
      on a.salesperson_id = b.salesperson_id
      group by a.salesperson_id , a.amount, a.order_number
      having max(b.amount) = a.amount;

  • @deepankarpathak5224
    @deepankarpathak5224 2 роки тому

    Hi, Can we do this,
    select max(order_number) as order_number,max(order_date) as dates, max(cust_id) as cust_id, salesperson_id,max(amount) as amt
    from int_orders
    group by salesperson_id

  • @adityaagrawal1731
    @adityaagrawal1731 2 роки тому

    select order_number,order_date,cust_id,salesperson_id,max(amount) as amount from int_orders1 group by salesperson_id
    i mean you have no where mentioned that you want order by order_number

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      We want order details of highest amount order by each sales person

  • @mathavansg9227
    @mathavansg9227 10 місяців тому

    select order_number,order_date,cust_id,salesperson_id,amount from int_orders
    group by salesperson_id HAVING max(amount) order by amount desc

  • @hustlerguy6091
    @hustlerguy6091 2 роки тому

    I always try to do the problems without looking at solution first. Thanks Ankit for making these kind of videos. My solution is different, but I don't know if it is more efficient or not.
    select o1.* from int_orders o1 LEFT JOIN int_orders o2 ON o1.salesperson_id=o2.salesperson_id AND o1.amount

    • @faizraina7946
      @faizraina7946 2 роки тому

      can u explain why u did o2.order no is null

  • @rashmidutta7151
    @rashmidutta7151 2 роки тому

    why I dont get any output..with the same:
    select o1.order_number,o1.order_date,o1.cust_id,o1.salesperson_id,o1.amount
    from int_orders o1 left join int_orders o2 on
    o1.salesperson_id=o2.salesperson_id
    group by o1.order_number,o1.order_date,o1.cust_id,o1.salesperson_id,o1.amount
    having o1.amount>max(o2.amount);
    can anyone help me out here?

  • @yashsaxena7754
    @yashsaxena7754 2 роки тому

    Would this be acceptable?
    select distinct t1.*
    from int_orders t1 join int_orders t2
    on t1.salesperson_id = t2.salesperson_id and t1.amount = (select max(amount) from int_orders t2 where t1.salesperson_id=t2.salesperson_id)

  • @AmanRaj-uf7wx
    @AmanRaj-uf7wx Рік тому

    select i.* from int_orders as i
    left join int_orders as o on i.salesperson_id= o.salesperson_id
    group by i.order_number, i.order_date, i.cust_id, i.salesperson_id, i.amount
    having i.amount >= max(o.amount)

  • @abb_raj1107
    @abb_raj1107 2 роки тому

    it can simply achieve by this way without join option, code below:
    select salesperson_id,max(amount)
    from int_orders
    group by salesperson_id

    • @ankitbansal6
      @ankitbansal6  2 роки тому

      We need full order details in output

    • @abb_raj1107
      @abb_raj1107 2 роки тому

      @@ankitbansal6 got it bro thanks

  • @ManeshBPandu
    @ManeshBPandu 2 роки тому

    Is there any extra logic here
    select salesperson_id,max(amount) from #int_orders group by salesperson_id i got only 4 rows as
    salesperson_id (No column name)
    1 460
    2 2400
    7 720
    8 1800
    this will work out right i might be wrong, is there any reason to that extreme i mean like having self join and comparing records and getting output. please correct me if i didn't understood the question

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      We need full order details not Just 2 columns

    • @ManeshBPandu
      @ManeshBPandu 2 роки тому +1

      @@ankitbansal6 ohh yeah yeah got it sorry my mistake. Thank you for the reply

  • @SudhirKumar-rl4wt
    @SudhirKumar-rl4wt 2 роки тому

    --find largest order by value for each person and order details
    -- without subquery , cte , window function , temp table
    drop table int_orders;
    CREATE TABLE int_orders(
    order_number number NOT NULL,
    order_date date NOT NULL,
    cust_id number NOT NULL,
    salesperson_id number NOT NULL,
    amount number NOT NULL
    );
    alter session set NLS_DATE_FORMAT='yyyy-mm-dd';
    INSERT INTO int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (30, '1995-07-14', 9, 1, 460);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (10, '1996-08-02' , 4, 2, 540);
    INSERT INTO int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (40, '1998-01-29' , 7, 2, 2400);
    INSERT INTO int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (50, '1998-02-03' , 6, 7, 600);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (60, '1998-03-02' , 6, 7, 720);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (70, '1998-05-06' , 9, 7, 150);
    INSERT into int_orders (order_number, order_date, cust_id, salesperson_id, amount) VALUES (20, '1999-01-30' , 4, 8, 1800);
    commit;
    --solution
    select max(ORDER_NUMBER) ORDER_NUMBER ,max(ORDER_DATE) ORDER_DATE ,max(CUST_ID) CUST_ID,SALESPERSON_ID,max(AMOUNT) AMOUNT
    from int_orders
    group by SALESPERSON_ID
    having (count(1)=1)
    union all
    select a.ORDER_NUMBER,a.ORDER_DATE,a.CUST_ID,a.SALESPERSON_ID,a.AMOUNT
    from int_orders a
    inner join int_orders b on a.salesperson_id=b.salesperson_id and a.amount > b.amount
    MINUS
    select a.ORDER_NUMBER,a.ORDER_DATE,a.CUST_ID,a.SALESPERSON_ID,a.AMOUNT
    from int_orders a
    inner join int_orders b on a.salesperson_id=b.salesperson_id and a.amount < b.amount
    ORDER_NUMBER ORDER_DATE CUST_ID SALESPERSON_ID AMOUNT
    ------------ ---------- ---------- -------------- ----------
    30 1995-07-14 9 1 460
    20 1999-01-30 4 8 1800
    40 1998-01-29 7 2 2400
    60 1998-03-02 6 7 720
    SQL>

    • @SudhirKumar-rl4wt
      @SudhirKumar-rl4wt 2 роки тому

      smaller solution post just started watching the video .
      select a.ORDER_NUMBER,a.ORDER_DATE,a.CUST_ID,a.SALESPERSON_ID,a.AMOUNT
      from int_orders a
      inner join int_orders b on a.salesperson_id=b.salesperson_id and a.amount >= b.amount
      MINUS
      select a.ORDER_NUMBER,a.ORDER_DATE,a.CUST_ID,a.SALESPERSON_ID,a.AMOUNT
      from int_orders a
      inner join int_orders b on a.salesperson_id=b.salesperson_id and a.amount < b.amount

    • @ankitbansal6
      @ankitbansal6  2 роки тому +1

      Thanks for posting 👏

    • @SudhirKumar-rl4wt
      @SudhirKumar-rl4wt 2 роки тому

      @@ankitbansal6 I think we can even further reduce the size of the query..first self join doesn't seem necessary..may be only directly selecting table minus 2nd itself should be fine

    • @SudhirKumar-rl4wt
      @SudhirKumar-rl4wt 2 роки тому

      because second self join gives all the smaller sales except largest one and substracting it from main table should be fine to give the desired result.

    • @SudhirKumar-rl4wt
      @SudhirKumar-rl4wt 2 роки тому

      SQL> --full table
      select a.ORDER_NUMBER,a.ORDER_DATE,a.CUST_ID,a.SALESPERSON_ID,a.AMOUNT
      from int_orders a
      MINUS
      --all smallers except largest
      select a.ORDER_NUMBER,a.ORDER_DATE,a.CUST_ID,a.SALESPERSON_ID,a.AMOUNT
      from int_orders a
      inner jSQL> oin int_orders b on a.salesperson_id=b.salesperson_id and a.amount < b.amount;
      ORDER_NUMBER ORDER_DAT CUST_ID SALESPERSON_ID AMOUNT
      ------------ --------- ---------- -------------- ----------
      30 14-JUL-95 9 1 460
      40 29-JAN-98 7 2 2400
      60 02-MAR-98 6 7 720
      20 30-JAN-99 4 8 1800
      SQL>