Pereiti prie turinio

Rekomenduojami pranešimai

Sveiki reikia pagalbos.

 

yra lenteles(supaprastinta):

Repair: ID InstrumentID Quantity Price

Instrument: ID RemontPrice

 

su tokia uzklausa paskaiciuoju suma visu Repair su reikiamu kinatmuoju: SELECT SUM(`Quantity`*`Price`) FROM `Repair` WHERE `InstrumentID`='$ID'

 

Dabar reikia pasirasyti uzklausa kuri paskaiciuotu suma ir atnaujintu Lenteles Instrumnet lauka Price:

 

Bandziau kazkaip taip,bet neveikia :(

 

UPDATE `Instrument` SET `RemontPrice` = '(SELECT SUM( `Repair`.`Quantity` * `Repair`.`Price` )

FROM `Repair`

WHERE `InstrumentID` = '$ID ')' WHERE `Instrument`.`ID` ='$ID';

Redagavo ghost_s
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Padump'ink SQL'ą su pora reikšmių jei nori tikslaus atsakymo.

O šiaip, atrodo, kad kabučių ten visur per daug. Visų pirma, ID nereikia skliausti. O ir to vidinio SELECT nereikia skliausti.

Greičiausiai, reiktų naudoti JOIN vietoj SELECT'o viduje, bet čia jau tavo reikalas.

 

P.S. RemontPrice :lol:

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Padump'ink SQL'ą su pora reikšmių jei nori tikslaus atsakymo.

O šiaip, atrodo, kad kabučių ten visur per daug. Visų pirma, ID nereikia skliausti. O ir to vidinio SELECT nereikia skliausti.

Greičiausiai, reiktų naudoti JOIN vietoj SELECT'o viduje, bet čia jau tavo reikalas.

 

P.S. RemontPrice :lol:

 

Atradau klaida tiesiog nereikio apostrofu pries skliaustus `RemontPrice` = '(SE

 

Del RemontPrice aciu, kad pastebejai :D :D :D Kazkokia nesamone gavos :D

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Jeigu nori, kad automatiškai settintųsi ta suma, tai siūlyčiau tau trigger'į 'Repair' lentelei parašyti, maždaug tokį:

CREATE TRIGGER repairPriceCount AFTER INSERT ON `Repair`
FOR EACH ROW 
BEGIN
 UPDATE `Instruments` I 
 SET I.`RemontPrice` = I.`RemontPrice` + NEW.`Quantity` * NEW.`Price`
 WHERE I.`ID` = NEW.InstrumentID;
END;

 

Tai toks trigeris automatiškai paupdeitins reikiamą instrumentą po to, kai painsertinsi naują repair'ą (čia jeigu logikos nesupainiojau, bet idėją turėtum pagaut).

Redagavo vitalikaz
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...