Solved

How to make this query?

Posted on 2013-01-30
3
156 Views
Last Modified: 2013-02-14
Hi!

Have a TABLEA that contains of this:
Item         SALES                             Prnr         Period
3023      60.000000000000            PU4812      201304
3023      60.000000000000            PU4812      201304
3023       60.000000000000      PU0413      201304
3023      60.000000000000            PU4412      201304
3023      40.000000000000            PU0413      201304
3023      40.000000000000            PU0413      201304
3023      40.000000000000            PU5212      201304
3023      40.000000000000            PU4412      201304
3023      7920.000000000000      PU5212      201304
3023        -2.000000000000         PU4812   201304

My problem is this:
I must insert missing records that not in Prset periode..
for Period= 201304

Must have this periods for Periode=201304
PU4412->PU4812->PU5212->PU0413
for every four months

Like SALES = 60, have all 4 periods right
SALES = 40, have all 4 periods right
SALES = 7920 misses -> PU4412->PU4812->PU0413
SALES = -2 Misses -> PU4412->PU5212->PU0413

So the final result wil be:

Item         SALES                             Prnr         Period
3023      60.000000000000            PU4812      201304
3023      60.000000000000            PU4812      201304
3023       60.000000000000      PU0413      201304
3023      60.000000000000            PU4412      201304
3023      40.000000000000            PU0413      201304
3023      40.000000000000            PU0413      201304
3023      40.000000000000            PU5212      201304
3023      40.000000000000            PU4412      201304
3023      7920.000000000000      PU5212      201304
3023        -2.000000000000         PU4812   201304
3023      7920.000000000000      PU4412      201304
3023      7920.000000000000      PU4812      201304
3023      7920.000000000000      PU0413      201304
3023        -2.000000000000         PU4412   201304
3023        -2.000000000000         PU5212   201304
3023        -2.000000000000         PU0413   201304


How can i do this ?
0
Comment
Question by:team2005
[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
  • 2
3 Comments
 
LVL 75

Accepted Solution

by:
Anthony Perkins earned 500 total points
ID: 38835208
This will give you the missing rows:
SELECT  a.Item, a.Sales, p.Prnr, a.Period
FROM    TableA A
        INNER JOIN (
                    SELECT  Item,
                            Sales
                    FROM    TableA A
                    WHERE   Period = 201304
                    GROUP BY Item,
                            Sales
                    HAVING  COUNT(*) < 4
                   ) A2 ON A.Item = A2.Item
                           AND A.Sales = A2.Sales
        CROSS JOIN (
                    SELECT DISTINCT
                            Prnr
                    FROM    TableA
                    WHERE   Period = 201304
                   ) p
WHERE   A.Prnr <> p.Prnr

Open in new window

0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 38835237
This is how I tested it:
DECLARE @TableA TABLE (
    Item integer,
    Sales money,
    Prnr varchar(10),
    Period integer)

INSERT  @TableA
        (Item, Sales, Prnr, Period)
VALUES  (3023, 60.000000000000, 'PU4812', 201304),
        (3023, 60.000000000000, 'PU4812', 201304),
        (3023, 60.000000000000, 'PU0413', 201304),
        (3023, 60.000000000000, 'PU4412', 201304),
        (3023, 40.000000000000, 'PU0413', 201304),
        (3023, 40.000000000000, 'PU0413', 201304),
        (3023, 40.000000000000, 'PU5212', 201304),
        (3023, 40.000000000000, 'PU4412', 201304),
        (3023, 7920.000000000000, 'PU5212', 201304),
        (3023, -2.000000000000, 'PU4812', 201304)

SELECT  a.Item, a.Sales, p.Prnr, a.Period
FROM    @TableA A
        INNER JOIN (
                    SELECT  Item,
                            Sales
                    FROM    @TableA A
                    WHERE   Period = 201304
                    GROUP BY Item,
                            Sales
                    HAVING  COUNT(*) < 4
                   ) A2 ON A.Item = A2.Item
                           AND A.Sales = A2.Sales
        CROSS JOIN (
                    SELECT DISTINCT
                            Prnr
                    FROM    @TableA
                    WHERE   Period = 201304
                   ) p
WHERE   A.Prnr <> p.Prnr

Open in new window


And here is the output:
Item	Sales	Prnr	Period
3023	7920.00	PU0413	201304
3023	7920.00	PU4412	201304
3023	7920.00	PU4812	201304
3023	-2.00	PU0413	201304
3023	-2.00	PU4412	201304
3023	-2.00	PU5212	201304

Open in new window

0
 
LVL 2

Author Closing Comment

by:team2005
ID: 38888423
Thanks
0

Featured Post

The Eight Noble Truths of Backup and Recovery

How can IT departments tackle the challenges of a Big Data world? This white paper provides a roadmap to success and helps companies ensure that all their data is safe and secure, no matter if it resides on-premise with physical or virtual machines or in the cloud.

Question has a verified solution.

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

The Delta outage: 650 cancelled flights, more than 1200 delayed flights, thousands of frustrated customers, tens of millions of dollars in damages – plus untold reputational damage to one of the world’s most trusted airlines. All due to a catastroph…
A Stored Procedure in Microsoft SQL Server is a powerful feature that it can be used to execute the Data Manipulation Language (DML) or Data Definition Language (DDL). Depending on business requirements, a single Stored Procedure can return differe…
Viewers will learn how the fundamental information of how to create a table.
Viewers will learn how to use the INSERT statement to insert data into their tables. It will also introduce the NULL statement, to show them what happens when no value is giving for any given column.

736 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