sql >> Databasteknik >  >> RDS >> Mysql

Hur data ordnas i MySql som standard

I InnoDB , rader lagras i primärnyckelordning. Om du använder LIMIT utan ORDER BY , får du alltid raderna med de lägsta primärnyckelvärdena, även om du infogat dem i slumpmässig ordning.

create table foo (id int primary key, x char(1), y int) engine=InnoDB;
insert into foo values (5, 'A', 123);
insert into foo values (9, 'B', 234);
insert into foo values (2, 'C', 345);
insert into foo values (4, 'D', 456);
insert into foo values (1, 'E', 567);
select * from foo;
+----+------+------+
| id | x    | y    |
+----+------+------+
|  1 | E    |  567 |
|  2 | C    |  345 |
|  4 | D    |  456 |
|  5 | A    |  123 |
|  9 | B    |  234 |
+----+------+------+

I MyISAM , rader lagras var de än passar. Till en början betyder det att rader läggs till i datafilen, men när du tar bort rader och infogar nya kommer luckorna som lämnas av raderade rader att återanvändas av nya rader.

create table bar (id int primary key, x char(1), y int) engine=MyISAM;
insert into bar values (1, 'A', 123);
insert into bar values (2, 'B', 234);
insert into bar values (3, 'C', 345);
insert into bar values (4, 'D', 456);
insert into bar values (5, 'E', 567);
select * from bar;
+----+------+------+
| id | x    | y    |
+----+------+------+
|  1 | A    |  123 |
|  2 | B    |  234 |
|  3 | C    |  345 |
|  4 | D    |  456 |
|  5 | E    |  567 |
+----+------+------+
delete from bar where id between 3 and 4;
insert into bar values (6, 'F', 678);
insert into bar values (7, 'G', 789);
insert into bar values (8, 'H', 890);
select * from bar;
+----+------+------+
| id | x    | y    |
+----+------+------+
|  1 | A    |  123 |
|  2 | B    |  234 |
|  7 | G    |  789 | <-- new row fills gap
|  6 | F    |  678 | <-- new row fills gap
|  5 | E    |  567 |
|  8 | H    |  890 | <-- new row appends at end
+----+------+------+

Ett annat undantagsfall om du använder InnoDB är om du hämtar rader från ett sekundärt index istället för från det primära indexet. Detta händer när du ser "Using index"-anteckningen i EXPLAIN-utgången.

alter table foo add index (x);
select id, x from foo;
+----+------+
| id | x    |
+----+------+
|  5 | A    |
|  9 | B    |
|  2 | C    |
|  4 | D    |
|  1 | E    |
+----+------+

Om du har mer komplexa frågor med kopplingar, blir det ännu mer komplicerat, eftersom du kommer att få raderna returnerade enligt standardordningen för den första tabellen som öppnas (där "först" är beroende av att optimeraren väljer tabellordningen), då rader från den sammanfogade tabellen kommer att vara beroende av ordningen på raderna från föregående tabell.

select straight_join foo.*, bar.* from bar join foo on bar.x=foo.x;
+----+------+------+----+------+------+
| id | x    | y    | id | x    | y    |
+----+------+------+----+------+------+
|  1 | E    |  567 |  5 | E    |  567 |
|  5 | A    |  123 |  1 | A    |  123 |
|  9 | B    |  234 |  2 | B    |  234 |
+----+------+------+----+------+------+

select straight_join foo.*, bar.* from foo join bar on bar.x=foo.x;
+----+------+------+----+------+------+
| id | x    | y    | id | x    | y    |
+----+------+------+----+------+------+
|  5 | A    |  123 |  1 | A    |  123 |
|  9 | B    |  234 |  2 | B    |  234 |
|  1 | E    |  567 |  5 | E    |  567 |
+----+------+------+----+------+------+

Summan av kardemumman är att det är bäst att vara tydlig:när du använder LIMIT , ange en ORDER BY .



  1. Hur man säkerhetskopierar och återställer en PostgreSQL-databas via DBeaver

  2. Använder SQL Server som en DB-kö med flera klienter

  3. Är en MySQL-vy snabbare än en vanlig fråga?

  4. Hämta de senaste posterna med GROUP BY