Una leccion: TODA TABLA DEBE TENER UN CAMPO CLAVE. Punto. Definele un campo Id autonumerico.
El porque te pasa el error es muy simple.... resulta que en la tabla esta estos datos
Nombre Apellido
Mario Montoya
Mario Montoya
Y visualmente en el grid tienes lo mismo
Nombre Apellido
Mario Montoya
Mario Montoya
Ahora, visualmente, haces esto:
Nombre Apellido
Mario Montoya
Y el componente obviamente hace esto:
DELETE FROM Nombres WHERE Nombre='Mario' AND Apellido='Montoya'
PERO VISUALMENTE es UNA SOLA FILA la que se borro, Y FISICAMENTE estas ejecutando una sentencia que borra DOS filas... cual de las dos, la primera o la segunda se debe borrar? Asi que como los programadores de las interfaces de datos saben que no pueden adivinar por vos, te sacan un lindo mensaje de error
es un error de logica no de datos. De hecho si manualmente ejecutas el DELETE no te saca el error porque explicitamente estas dando la orden y se supone, sabes lo que haces.
Es por eso, que la unica forma que hay para que la accion visual sea = a la fisica es:
Id Nombre Apellido
1 Mario Montoya
2 Mario Montoya
Porque ahora si borras la primera fila, la accion es clara. De pronto si vienes de motores de escritorio como Fox o Paradox no pasaba esto ya que existe un ID intrinseco que es:
RecNo Nombre Apellido
1 Mario Montoya
2 Mario Montoya
lo cual resolvia el problema...