Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   Articulo -> Ventas - Borrar Articulo (https://www.clubdelphi.com/foros/showthread.php?t=26163)

hmoner 14-10-2005 16:28:08

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...

alresave 14-10-2005 16:37:31

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.

Neftali [Germán.Estévez] 14-10-2005 16:38:35

Cita:

Empezado por hmoner
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...

Bueno, para eso está la integridad referencial.
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).

hmoner 14-10-2005 17:11:27

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 !

Neftali [Germán.Estévez] 14-10-2005 17:17:44

¿Con qué Base de Datos o SGBD estás trabajando?

hmoner 14-10-2005 17:34:32

Trabajo con NexusDB y mySQL
www.nexusdb.com

Neftali [Germán.Estévez] 14-10-2005 17:48:40

NexusDB V2 SQL main features

  • Standard SQL:2003
  • Views
  • Referential Integrity
  • Triggers - Active Database
  • Stored Procedures and Functions
  • SQL/PSM Procedure Language
  • Transaction Management
  • Fulltext Index Support
  • Tools
En cuanto a MySQL por lo que se lee en éste post no las tiene:
http://www.clubdelphi.com/foros/show...43&postcount=9

hmoner 14-10-2005 18:24:54

De lujo !
gracias por la info NefTali !


La franja horaria es GMT +2. Ahora son las 14:43:43.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi