![]() |
Articulo -> Ventas - Borrar Articulo
Hola Amigos
Tengo una duda "de principiante" Tengo una tabla Articulo y una Ventas En la tabla Ventas tengo incluido el ID del articulo que he vendido, no ? Bueno, quisiera saber cual es el metodo o forma que utilizan ustedes para que cuando el usuario borre un articulo, la tabla ventas no contenga referencias inexistentes, y por ende el programa no de 13592 errores...:o Desde ya muchas gracias... |
no agregues a ventas el artículo hasta que no haya vuelta atrás y te evitas problemas. Mantenlo en memoria y si el usuario lo borra lo quitas de memoria. En caso de que sea imperativo que lo estés guardando, crea una tabla ventas y otra detalleventas
en la de ventas guardas el total de la venta y le asignas un id y en la de detalleventas guardas el id de la venta con el id del articulo. si tienes que borrar un articulo lo borras usando el id de la venta y en tu sql ponle al final del delete la instruccion "limit 1" para que solo borre una concurrencia del articulo. |
Cita:
La idea es que no se debería poder borrar ese artículo, para que las ventas no queden "huerfanas"; Si tu Base de Datos no soporta integridad referencial, pues una opción sería hacer la comprobación antes del borrado manualmente, es decir, revisar "si hay alguna venta cuyo ID sea el que voy a borrar", aunque ésto puede ser extremadamente lento. Si soporta integridad referecial y está bien definida, la propia Base de Datos debería impedir ese borrado, o borrar las ventas asociadas (en caso de definir borrados en cascada). |
esa era la palabra
integridad referencial !! voy a ver ahora mismo si el motor soporta esa opcion, pero creo que por ahora debere verificar si existe venta del articulo antes de borrarlo. gracias, saludos ! |
¿Con qué Base de Datos o SGBD estás trabajando?
|
Trabajo con NexusDB y mySQL
www.nexusdb.com |
NexusDB V2 SQL main features
http://www.clubdelphi.com/foros/show...43&postcount=9 |
De lujo !
gracias por la info NefTali ! |
La franja horaria es GMT +2. Ahora son las 23:38:31. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi