Po pierwsze, jeśli wartości są takie same, MySQL nie zaktualizuje wiersza, więc liczba wierszy, których to dotyczy, będzie wynosić 0.
Rozwiązanie tego problemu:
$query="SELECT count(*) as cnt FROM `songs` WHERE `music_name`='$name', `price`='$price' AND `genre`=$genre" ;
/****get count from the query******/
if(count > 0 ) {
//update the table row
}
else{
//insert the table row
}