Yo coincido con Roman, siempre uso claves artificiales excepto cuando hay algun campo candidato a clave única que no tenga forma de introducir errores de captura, por ejemplo: un número de factura.
Te comento que además los incrementales tienen la gran ventaja de que (al menos en MySQL y tablas MyISAM) puedes usar varios a la vez y el motor se encarga de ir creando categorias. Por ejemplo para un pedido y sus lineas, defino el pedido con una clave autoinc para la primaria y la tabla de lineas le pongo un campo "normal" que contiene la clave externa y un campo autoinc ambos como clave primaria de manera que MySQL en automático me va generando numeros de línea independientes para cada pedido.
|