FAQ |
Kalender |
![]() |
#1 | ||
|
|||
Administratör
|
Hur kollar man på snabbaste sätt ifall en rad redan existerar i en databas?
Vad jag vill göra är att kolla ifall en textsträng redan existerar på någon rad i databasen. Jag har 2 fält i tabellen, fras och antal. Vad programmet ska göra är att kolla om $fras redan existerar ... gör den det så blir det en UPDATE och antal plusas på med 1. Gör den inte det så ska det bli en INSERT. Alternativ är att göra en helt vanlig selectfråga. SELECT fras COUNT(*) FROM tabell WHERE fras='$fras'. Men finns det något smidigare och snabbare sätt? Databasen kommer nämligen bli rätt stor. MySQL manualen gör mig lite förvirrad också...
__________________
www.hus.se - www.hantverkare.se - www.qualityunlimited.com - www.test.se - www.kampanj.se |
||
![]() |
![]() |
![]() |
#2 | ||
|
|||
Supermoderator
|
Vad använder du för språk? I PHP blir det såhär:
Kod:
$que = "UPDATE tabell SET antal=antal+1 WHERE fras='$fras'"; $res = mysql_query( $que ); if (mysql_affected_rows() != 1) { // Inte uppdaterad => finns ingen sen tidigare $que = "INSERT INTO tabell SET antal=0, fras='$fras'"; $res = mysql_query( $que ); } ![]() |
||
![]() |
![]() |
![]() |
#3 | ||
|
|||
Administratör
|
Jepp, det är PHP!
Tackar! Det var ett bra exempel ![]()
__________________
www.hus.se - www.hantverkare.se - www.qualityunlimited.com - www.test.se - www.kampanj.se |
||
![]() |
![]() |
![]() |
#4 | ||
|
|||
Supermoderator
|
Hehe, jo man har sina ups and downs... se bara på Ericsson... :P
|
||
![]() |
![]() |
Svara |
|
|