INSERT INTO from one table to another table show duplicate row ??? WHY

  • mrceski

    SSC Enthusiast

    Points: 103

    I use this code:

    INSERT INTO
    TableIzlez ([BrojNaSmetka],[Artikal],[Sifra],[Kolicina],[Cena_P],[Cena_N],[Prodavac],
    [Datum],[Fiskalna],[MasaBroj],[Oddel],[Zatvorena],[PodGrupa],[Cena_Produkti],[TipNaSmetka],[DDV],[Den])
    SELECT
    BrojNaSmetka,Artikal,Sifra,Kolicina,Cena_P,Cena_N,Prodavac,Datum,
    Fiskalna,MasaBroj,Oddel,Zatvorena,PodGrupa,Cena_Produkti,TipNaSmetka,DDV,'19.04.2018'
    FROM TableIzlezDneven

    Aftrer this code I delete the table TableIzlezDneven

    DELETE FROM TableIzlezDneven

    Sometimes I get double records at the TableIzlez.
    I can't understand why show double records.
    In this table with red row show double records ( this is from TableIzlez).

  • Jeff Moden

    SSC Guru

    Points: 994238

    mrceski - Sunday, April 22, 2018 6:01 AM

    I use this code:

    INSERT INTO
    TableIzlez ([BrojNaSmetka],[Artikal],[Sifra],[Kolicina],[Cena_P],[Cena_N],[Prodavac],
    [Datum],[Fiskalna],[MasaBroj],[Oddel],[Zatvorena],[PodGrupa],[Cena_Produkti],[TipNaSmetka],[DDV],[Den])
    SELECT
    BrojNaSmetka,Artikal,Sifra,Kolicina,Cena_P,Cena_N,Prodavac,Datum,
    Fiskalna,MasaBroj,Oddel,Zatvorena,PodGrupa,Cena_Produkti,TipNaSmetka,DDV,'19.04.2018'
    FROM TableIzlezDneven

    Aftrer this code I delete the table TableIzlezDneven

    DELETE FROM TableIzlezDneven

    Sometimes I get double records at the TableIzlez.
    I can't understand why show double records.
    In this table with red row show double records ( this is from TableIzlez).

    

    Is the TableIzlez table empty before you do the inserts?

    --Jeff Moden


    RBAR is pronounced "ree-bar" and is a "Modenism" for Row-By-Agonizing-Row.
    First step towards the paradigm shift of writing Set Based code:
    ________Stop thinking about what you want to do to a row... think, instead, of what you want to do to a column.
    "If you think its expensive to hire a professional to do the job, wait until you hire an amateur."--Red Adair
    "Change is inevitable... change for the better is not."
    When you put the right degree of spin on it, the number 3|8 is also a glyph that describes the nature of a DBAs job. 😉

    Helpful Links:
    How to post code problems
    Create a Tally Function (fnTally)

  • mrceski

    SSC Enthusiast

    Points: 103

    No TableIzlez is not empty.
    That table is  fill from TableIzlezDneven every day (one time) and TableIzlezDneven is deleted one time per day , and next day start TableIzlezDneven empty.

    Thanks for help

  • Jeff Moden

    SSC Guru

    Points: 994238

    mrceski - Sunday, April 22, 2018 1:50 PM

    No TableIzlez is not empty.
    That table is  fill from TableIzlezDneven every day (one time) and TableIzlezDneven is deleted one time per day , and next day start TableIzlezDneven empty.

    Thanks for help

    Then the answer is probably pretty simple.  There are rows in the TableIzlezDneven table that already exist in the TableIzlez   from other loads of the TableIzlezDneven table.  There appears to be nothing that you've done to check for duplicates in the TableIzlezDneven from one day 'til the next and you've certainly done nothing to prevent such duplicates from entering the TableIzlez

    --Jeff Moden


    RBAR is pronounced "ree-bar" and is a "Modenism" for Row-By-Agonizing-Row.
    First step towards the paradigm shift of writing Set Based code:
    ________Stop thinking about what you want to do to a row... think, instead, of what you want to do to a column.
    "If you think its expensive to hire a professional to do the job, wait until you hire an amateur."--Red Adair
    "Change is inevitable... change for the better is not."
    When you put the right degree of spin on it, the number 3|8 is also a glyph that describes the nature of a DBAs job. 😉

    Helpful Links:
    How to post code problems
    Create a Tally Function (fnTally)

  • mrceski

    SSC Enthusiast

    Points: 103

    Let me clarify what exactly this is about.
    It is a restaurant program, where all orders in the restaurant are recorded in TableIzlezDneven during per one day.
    At the end of the day, all orders from daily orders (TableIzlezDneven) are transferred to all orders (TableIzlez that database is for records for all days)
    and after transferred records table TableIzlezDneven deleted = empty table (DELETE FROM TableIzlezDneven ).
    This means that all daylight orders should be transferred to the database for all days. Because they are needed for periodic reports and must be as they are written in the table TzbleIzlezDneven so they can be transferred to the table for all days.
    In this picture you will see the some records from TableIzlezDneven transferred on TableIzlez two times (some records - see red line and see the time is some)
    see this row where ID=170834 and row ID=170835 is some records but must be only one. In table with red row is duplicate records.

  • pietlinden

    SSC Guru

    Points: 62394

    you never check the destination table for existing records. Why not?

  • mrceski

    SSC Enthusiast

    Points: 103

    You mean check existing records before INSERTI NTO (transfer from TableIzlezDneven to Tablelzlez) or after INSERT INTO.

  • Jeff Moden

    SSC Guru

    Points: 994238

    mrceski - Sunday, April 22, 2018 3:09 PM

    You mean check existing records before INSERTI NTO (transfer from TableIzlezDneven to Tablelzlez) or after INSERT INTO.

    You first need to ensure that there are no duplicates in the TableIzlezDneven table itself.  Then you need to see if any rows in the TableIzlezDneven table already exist in the Tablelzlez.

    --Jeff Moden


    RBAR is pronounced "ree-bar" and is a "Modenism" for Row-By-Agonizing-Row.
    First step towards the paradigm shift of writing Set Based code:
    ________Stop thinking about what you want to do to a row... think, instead, of what you want to do to a column.
    "If you think its expensive to hire a professional to do the job, wait until you hire an amateur."--Red Adair
    "Change is inevitable... change for the better is not."
    When you put the right degree of spin on it, the number 3|8 is also a glyph that describes the nature of a DBAs job. 😉

    Helpful Links:
    How to post code problems
    Create a Tally Function (fnTally)

Viewing 8 posts - 1 through 8 (of 8 total)

You must be logged in to reply to this topic. Login to reply