Mitenkäs MySQL onnistuu, et päivitetään tietoja mikäli tietokannassa semmoinen on ellei niin lisätään uusi?
Pitääkös tehdä näin.
UPDATE ...... Jos epäonnistui niin sit INSERT ..... Eikö ole helpompaa tapaa?
Tietojen päivitys MySQL?
7
741
Vastaukset
- Neratetst
---
- ollenkaan
Käytät IF EXISTS jolla löydät olemassa olevat ja sitten UPDATE. Jos ei löydy niin sitten INSERT.
Ei muuten ole mitenkään MySQL-kohtainen vaan sama juttu kaikilla SQL-kannoilla. - Neratetst
ollenkaan kirjoitti:
Käytät IF EXISTS jolla löydät olemassa olevat ja sitten UPDATE. Jos ei löydy niin sitten INSERT.
Ei muuten ole mitenkään MySQL-kohtainen vaan sama juttu kaikilla SQL-kannoilla.Kerroppas miten?
Yritin Googlettaa, mut löyty vain taulukoiden poistoa jotka ei sovi tähän tarkoitukseen.
Löysin INSERT INTO wordcount (word,count) VALUES ('a_word',1) ON DUPLICATE KEY UPDATE count=count 1; - Neratetst
Neratetst kirjoitti:
Kerroppas miten?
Yritin Googlettaa, mut löyty vain taulukoiden poistoa jotka ei sovi tähän tarkoitukseen.
Löysin INSERT INTO wordcount (word,count) VALUES ('a_word',1) ON DUPLICATE KEY UPDATE count=count 1;http://mysql.com/doc/refman/5.0/en/insert-on-duplicate.html tuon siis löysin.
- ollenkaan
Neratetst kirjoitti:
Kerroppas miten?
Yritin Googlettaa, mut löyty vain taulukoiden poistoa jotka ei sovi tähän tarkoitukseen.
Löysin INSERT INTO wordcount (word,count) VALUES ('a_word',1) ON DUPLICATE KEY UPDATE count=count 1;>Kerroppas miten?
Jos oletetaan että olet päivittämässä varaosataulua niin syntaksi menee jotenkin noin:
if EXISTS (SELECT 1 FROM varaosat WHERE osa_ID=@haku)
UPDATE varaosat ... WHERE osa_ID = @haku
else
INSERT varaosat... - Neratetst
ollenkaan kirjoitti:
>Kerroppas miten?
Jos oletetaan että olet päivittämässä varaosataulua niin syntaksi menee jotenkin noin:
if EXISTS (SELECT 1 FROM varaosat WHERE osa_ID=@haku)
UPDATE varaosat ... WHERE osa_ID = @haku
else
INSERT varaosat...Ensiksi kiitoksia todella paljon testaan tuota illemmal.
Itselläni on käytössä MySQL 5 joten alikyselyt ei ole ongelma, mutta MySQL 4 ne eivät toimi. Ilmeisesti tuo ei ole alikysely ja toimii MySQL 4?
Kumpaa tapaa suosittelet tätä vai tuota minun löytämääni? Ja miksi. - PIProd
Neratetst kirjoitti:
Ensiksi kiitoksia todella paljon testaan tuota illemmal.
Itselläni on käytössä MySQL 5 joten alikyselyt ei ole ongelma, mutta MySQL 4 ne eivät toimi. Ilmeisesti tuo ei ole alikysely ja toimii MySQL 4?
Kumpaa tapaa suosittelet tätä vai tuota minun löytämääni? Ja miksi.Itse olen käyttänyt ohjelmissani yksinkertaisissa kannoissa updaten sijaan käytäntöä delete -> insert.
Tämähän tekee periaatteessa päivityksen, delete suoritetaan jos primary key on tiedossa. Näin ollen ei tarvitse tehdä update lle omaa toiminnallisuutta ollenkaan.
Ongelmia tulee tietenkin jos on ko tauluun on paljon relaatioita pääavaimen kautta (jopa hajoavia / tuhoavia sellaisia), tai insert on hankalampi kuin update. Mutta jos insert on yksinkertainen ja relaatioita ei ole tai ne voidaan helposti korjata tämä on yksi tapa.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
- 1275705
Mikä on vaikeinta siinä, että menetti yhteyden kaivattuun, jota vielä ajattelee?
Mikä jäi kaihertamaan? Jos jokin olisi voinut mennä toisin, mitä se olisi ollut? Mitä olisit toivonut vielä ehtiväsi san3952469- 1312400
Persut rahoittavat velkarahalla rikkaiden ökyelämää
Minkä vuoksi persut eivät leikkaa rikkailta, joilla on maksukykyä? Tuskinpa tuo persujen käytös saa Suomen kansalta hyv42042- 56956
- 10922
Kun ei numeroa
niin en edes voi viestittää, et suunnitelmiin tuli muutos. Ikävä on, ja kasvaa vaan🤍8912- 51872
- 76795
Temusta tilaamiseen tulee muutos
Alle 150 euron tullivapaus poistuu. Vihdoinkin kankea EU saa jotakin aikaiseksi. https://www.iltalehti.fi/digiuutiset/101755