Ver Mensaje Individual
  #5 (permalink)  
Antiguo 03/06/2010, 12:30
Avatar de gnzsoloyo
gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 17 años
Puntos: 2658
Respuesta: Definir auto_increment

Además delo dicho, MySQL omite el uso de la PK en el ordenamiento de la subconsultas cuando hay un campo AUTO_INCREMENT.
Usando tu propio ejemplo:
Código MySQL:
Ver original
  1. CREATE TABLE  `tabla` (
  2.   `nombre` varchar(20) NOT NULL default '',
  3.   `numero` int(10) NOT NULL auto_increment,
  4.   PRIMARY KEY  (`nombre`),
  5.   KEY `numero` (`numero`)
  6.  
  7. INSERT INTO TABLA(NOMBRE)
  8.     VALUES('UNO'), ('DOS'), ('TRES'), ('CUATRO'), ('CINCO');
  9.  
  10. SELECT * FROM TABLA;
  11. +--------+--------+
  12. | nombre | numero |
  13. +--------+--------+
  14. | UNO    |      1 |
  15. | DOS    |      2 |
  16. | TRES   |      3 |
  17. | CUATRO |      4 |
  18. | CINCO  |      5 |
  19. +--------+--------+

Como se puede apreciar, la consulta no se ha ordenado por la columna nombre, que es PK y por tanto debería ser la usada como ordenador (es el modo por default de MySQL), sino por numero, que es auto_increment.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)

Última edición por gnzsoloyo; 03/06/2010 a las 13:14