Eine Transaktion bedeutet ja "Alles oder Nichts", d.h. man muss sich überlegen, welche Daten unabdingbar zusammengehören. Im Fehlerfall werden dann natürlich alle Änderungen innerhalb der aktuellen Transaktion verworfen. Außerdem sollte man nach Möglichkeit lang laufende Transaktionen vermeiden. Aus diesem Grund ist es z.B. ungeschickt, Daten clientseitig zu bearbeiten und einzelne Update-Befehle zum Server zu schicken, wenn man das per
SQL auch auf den Server abwälzen kann (gut, bei einem INSERT wird das ja nicht anders gehen als Einzelbefehle). Hat man sehr viele Daten, die nicht funktional voneinander abhängig sind, kann ein Commit alle X Datensätze nicht schaden. Man muss sich ja auch vor Augen halten, dass jede Transaktion den Server belastet, schließlich muss er den ganzen Schmu ja erstmal cachen.