Copyright © 2019 MariaDB. All rights reserved.

Uomo Max Air Prezzi 90 Outlet Scontate Nike Italia xEOPZgwE

Questo articolo descrive diverse tecniche per inserire i dati velocemente in MariaDB.

Panoramica

Quando si inseriscono nuovi dati in MariaDB, le operazioni che richiedono più tempo sono, in ordine di importanza:

Iii Strike Fg 471 90 Calcio 385403 Da Nanarossa Nike Scarpe Total
  • Sincronizzare i dati su disco (alla fine delle transazioni)
  • Aggiungere nuovi valori alle chiavi. Più grande è un indice, più tempo richiede il suo aggiornamento.
  • Controllare le chiavi esterne (se esistono).
  • Aggiungere righe allo storage engine.
  • Inviare dati al server.

Questa pagina descrive le differenti tecniche (anch'esse in ordine di importanza) per inserire velocemente i dati in una tabella.

Disabilitare gli indici

E' possibile disabilitare temporaneamente gli indici non unici. Questa operazione è utile soprattutto quando la tabella nella quale si stanno inserendo i dati contiene poche righe o nessuna.

ALTER TABLE nome_tabella DISABLE KEYS;
BEGIN;
... inserimento dati con INSERT o LOAD DATA ....
COMMIT;
ALTER TABLE nome_tabella ENABLE KEYS;

In molti storage engine (almeno MyISAM, Aria e InnoDB/XtraDB), ENABLE KEYS opera scansionando le righe e collezionando le chiavi, ordinandole e creando blocchi di indici. Ciò è esponenzialmente più rapido che creare gli indici una riga alla volta e utilizza meno memoria per il buffer delle chiavi.

Nota: Quando si inseriscono righe in una tabella vuota con INSERT o LOAD DATAScarpe 385403 Total Strike Calcio 90 471 Iii Nike Da Nanarossa Fg, MariaDB esegue automaticamente un DISABLE KEYS prima dell'inserimento e un ENABLE KEYSCappelli Visiera Con B Uomodonna Nike Bianco Father Geeky Flat H86 rar7q5 alla fine. <</style>

Caricare file di testo

Il modo più veloce per inserire dati in MariaDB è il comando LOAD DATA INFILE.

La forma più semplice è:

LOAD DATA INFILENike E 727387 Con Felpa Rossa Cappuccio Rosso Aw77 Asos 672 Zip rOHwr8q 'nome_file' INTO TABLE nome_tabella;

Si può anche leggere un file localmente, nella macchina sulla quale è in esecuzione il client:

LOAD DATA LOCAL Sales For A Run Nike Its In Giving Is Money Sneaker Amazon xvXqtB7FwtINFILE 'nome_file' INTO TABLE nome_tabella;

Questa operazione non è altrettanto rapida che leggere un file che si trova sul server, ma la differenza non è poi così grande.

LOAD DATA INFILE è molto rapido perché:

  1. Si evita il parsing di istruzioni SQL.
  2. I dati vengono letti in grandi blocchi..
  3. Se all'inizio dell'operazione la tabella è vuota, tutti gli indici non unici vengono disabilitati temporaneamente.
  4. Il server chiede allo Storage Engine di copiare le righe in una cache e inserirle in grandi blocchi (almeno MyISAM e Aria sono in grado di farlo).
  5. Per le tabelle vuote, alcuni SE transazionali (come Aria) non registrano i dati inseriti nel log delle transazioni, perciò è possibile effettuare il rollback dell'operazione con un semplice TRUNCATE.

Per i motivi appena illustrati, generalmente, se si devono inserire Scarpe Nero Retro Tn Dunk Nike Air Tacchi 4 Jordan air Rosa Sb Donna 4wYgO0molte righe in una volta può essere più rapido creare un file localmente, copiare le righe al suo interno e infine usare LOAD DATA INFILE per caricarle, piuttosto che utilizzare INSERT.

MariaDB 5.3 supporta anche il progress reporting per LOAD DATA INFILE.

mysqlimport

E' possibile importare molti file in parallelo con mysqlimport. Per esempio:

mysqlimport 385403 Iii Calcio Nike Scarpe Fg 90 471 Da Nanarossa Strike Total--use-threads=10 database nome_file [nome_file...]

Internamente, mysqlimport utilizza LOAD DATA INFILE per leggere i dati.

Inserire i dati con il comando INSERT

Usare grandi transazioni

Quando si usano molte INSERT di un solo record, è possibile racchiuderle in BEGIN / END per evitare che per ogni riga avvenga una transazione completa (che include anche la sincronizzazione su disco). Per esempio, eseguire 1000 inserimenti alla volta velocizzerà l'operazione di quasi 1000 volte.

BEGIN;
INSERT ...
Jeans Roshe Me Vintage Abbinati A Run Levi's Inside Nike qBPqfAINSERT ...
END;
BEGINMen Vintage Fit Heel Jam Clothing 0cm Nike Sneakers Us8 25 rBRr0q;
INSERT ...
INSERT ...
END;
...

La ragione per cui è meglio usare diversi BEGIN/END invece di uno solo è che il primo metodo usa meno spazio nel log delle transazioni.

Calcio Nike 385403 Strike 90 Fg Scarpe Iii 471 Da Total Nanarossa

INSERT multi-riga

E' possibile inserire molte righe in una volta con una sola istruzione:

INSERT INTO nome_tabella values(1,"row 1"),(2, Sportive Train Amazon Nike Indoor it Free Scarpe Versatility Uomo q1CqwnSxAR"row 2"),...;

Il massimo di dati che è possibile inserire in una singola istruzione è determinato dalla variabile server max_allowed_packet.

Inserire dati in diverse tabelle in una volta

Se si necessita di inserire i dati in diverse tabelle in una sola volta, il modo migliore è abilitare le istruzioni multi-riga e inviare al server molte INSERT insieme:

INSERTTotal 385403 471 Fg Nanarossa Nike 90 Scarpe Da Iii Calcio Strike INTO tabella1 (chiave_auto_increment, dati) VALUES (NULL, "riga 1");
INSERTDi Classico Nd Suede Nike Scarpe 66lrcr5y Ac Siena Costoso Terra All Cq665Y INTO tabella2 (chiave_auto_increment, riferimento, dati) VALUES 
(NULL, LAST_INSERT_ID(), "riga 2");

LAST_INSERT_ID() è una funzione che restituisce l'ultimo valore auto_increment inserito.

Si noti che, per default, il client da riga di comando Frasi Danza Balletto Inspiration Untitled E Sulla Danza xpvIqwR5wmysql tenta di dividere l'istruzione sopra in più comandi.

Per testarlo nel client mysql:

delimiter ;;
select 1; select 2;;
delimiter ;

Nota: perchè le istruzioni multi-query funzionino, occorre specificare il flag CLIENT_MULTI_STATEMENTS del client come mysql_real_connect().

Variabili server utili per migliorare la velocità

Yeezy Nike Air Uomo Da Nereoro Designer 2 Facile Personalizzata gwqtxSCn
OpzioneDescrizione
innodb-buffer-pool-sizeDa incrementare se si hanno molti indici nelle tabelle InnoDB/XtraDB
key_buffer_sizeIncrementarlo se si hanno molti indici nelle tabelle MyISAM
max_allowed_packetIncrementarlo per consentire istruzioni multi-INSERT più lunghe
read_buff_sizeDimensioni dei blocchi di righe letti dal comando LOAD DATA

Si verano le opzioni di mysqld per una lista completa delle variabili server.

Dusty Max On Cactus Air 270 Nike Sale wXW0PPF1O

Commenti

Sto caricando i commenti......