Marcar registros en lugar de eliminarlos
Publicado por casares (1 intervención) el 21/11/2005 05:47:30
Mi problema es el siguiente:
Por politica del cliente los registros no se deben eliminar de la base de datos, en su lugar deben marcarse de alguna forma y considerarse eliminados. Esto no es problema, simplemente agrego un campo "borrado" y lo establezco a true cuando lo considere eliminado. Hasta ahi bien.
El problema radica en que pierdo las eliminaciones en cascada, y por consiguiente estoy obligado a programarlas. Lo cual no es un problema, solo implica mas trabajo.
Luego, todo se complica más cuando sucede que la base de datos es utilizada por varios desarrolladores para diferentes aplicaciones que utilizan tablas comunes. esto implica que las actualizaciones en cascada programadas deben incluir las tablas hijas de estos últimos, esto los obligaria a modificar los procedimientos almacenados creados por otros.... etc lo que nos lleva a un codigo muy dificil de mantener.
mi pregunta es
- Existe alguna solución concreta a situaciones de este tipo.?, quiero decir SQL Server proporciona algo al respecto o hay alguna forma común de hacerlo.
En caso de que no.
- Es posible obtener un listato de todas las relaciones de una tabla?
Con esto resolvería el problema ya que utilizaría esta lista para ir a cada una de las tablas hijas y marcar los registros coincidentes.
desde ya gracias por interesarse.
Por politica del cliente los registros no se deben eliminar de la base de datos, en su lugar deben marcarse de alguna forma y considerarse eliminados. Esto no es problema, simplemente agrego un campo "borrado" y lo establezco a true cuando lo considere eliminado. Hasta ahi bien.
El problema radica en que pierdo las eliminaciones en cascada, y por consiguiente estoy obligado a programarlas. Lo cual no es un problema, solo implica mas trabajo.
Luego, todo se complica más cuando sucede que la base de datos es utilizada por varios desarrolladores para diferentes aplicaciones que utilizan tablas comunes. esto implica que las actualizaciones en cascada programadas deben incluir las tablas hijas de estos últimos, esto los obligaria a modificar los procedimientos almacenados creados por otros.... etc lo que nos lleva a un codigo muy dificil de mantener.
mi pregunta es
- Existe alguna solución concreta a situaciones de este tipo.?, quiero decir SQL Server proporciona algo al respecto o hay alguna forma común de hacerlo.
En caso de que no.
- Es posible obtener un listato de todas las relaciones de una tabla?
Con esto resolvería el problema ya que utilizaría esta lista para ir a cada una de las tablas hijas y marcar los registros coincidentes.
desde ya gracias por interesarse.
Valora esta pregunta


0