Como bien dices, la forma de conseguir eso es utilizar transacciones.
Antes de empezar las inserciones haces un BeginTrans, realizas todas las inserciones y al acabar, si ha habido algun problema lanzas un RollbackTrans, para anular todo, si ha ido bien un CommitTrans para aceptar topdo.
Es sistema es bastante universal, aunque varía levemente dependiendo de los componentes que estés utilizando para conectarte a la Base de Datos. No comentas qué componentes ni qué BD utilizas, así que no puedo concretar más.
Si buscas en los foros sobre estos métodos seguro que encuentras más info.
|