Yo creo que de entrada el diseño de la tabla está equivocado pues de acuerdo a lo que mencionas se obtiene que "No puede haber más de un registro con el mismo CODREPUESTO y el mismo CODIGO". Me huele a que CODREPUESTO es una clave artificial (un vil consecutivo u otro tipo) y CODIGO es la traducción a lenguaje "humano" de CODREPUESTO. Me parece que bastaría con que la tabla tenga como clave primaria una u otra. De acuerdo a tu caso CODREPUESTO es nuestra clave primaria y puede haber N registros que compartan el mismo CODREPUESTO pero difente CODIGO".
La pega viene cuando vemos que CODIGO al parecer puede ser capturado posteriormente a la creación del registro, por lo que en todo caso solo podría haber un solo registro en donde CONREPUESTO tenga valor y CODIGO sea nulo o en blanco.
Sería mejor que nos regresaras un poco hacia atrás en el modelado de tu tabla o bien el caso de uso, ya que es más sencillo de entender que es lo que necesitas en realidad
|