Blog - Ultime notizie
Mysql E Comandi Bash – Come Dividere Un File Sql Per Permettere Un Import Del Data Base

Mysql e comandi bash – come dividere un file sql per permettere un import del data base

Spezzettare un file .sql enorme in più parti può essere una manna dal cielo per la gestione e l’importazione.
Soprattutto se il problema è il file dump mysql enorme che non è possibile importare tramite interfaccia grafica del DBMS phpmyadmin.
Ti propongo un comando bash piuttosto semplice (e flessibile) che divide il file in N parti di dimensione simile:

🧩 Opzione 1: Split in N parti (es. 10 o 20)

bash

split -n l/10 -d --additional-suffix=.sql file_origine.sql parte_

Spiegazione:

  • -n l/10 → divide il file in 10 parti uguali per numero di righe.
  • -d → aggiunge i numeri (00, 01, 02…) invece di lettere (aa, ab, ac…).
  • –additional-suffix=.sql → aggiunge .sql ai file risultanti.
  • parte_ → prefisso dei file di output (parte_00.sql, parte_01.sql, ecc).

📌 Cambia 10 con 20 o quello che preferisci.

🛠️ Opzione 2: Split per numero di righe (es. ogni 1000 righe)

Se preferisci tagliarlo in base a un numero fisso di righe:

bash

split -l 1000 -d --additional-suffix=.sql file_origine.sql parte_

⚠️ Attenzione se il file SQL ha transazioni o comandi multilinea
Il metodo sopra è “cieco”: taglia a prescindere da contenuto o sintassi. Se i tuoi file SQL hanno transazioni (BEGIN…COMMIT) o query multi-riga, potresti rischiare di troncare comandi a metà.

🧩 Opzione 3: Script in Bash con una divisione più intelligente delle query

Qui di seguito propongo anche la versione “intelligente” in Bash, che taglia il file SQL in blocchi completi, cercando di non spaccare a metà i comandi tipo INSERT, CREATE, ALTER, DROP, ecc.

L’idea è: leggiamo riga per riga e scriviamo su un file finché raggiungiamo un certo numero di istruzioni SQL complete, mantenendo la coerenza sintattica.

Ecco uno script Bash che lo fa:

🧠 Script Bash “smart splitter” per file SQL
bash

#!/bin/bash

input_file="file_origine.sql"
output_prefix="parte_"
max_statements_per_file=100  # puoi cambiarlo come vuoi

statement_count=0
file_index=0
output_file="${output_prefix}$(printf "%02d" $file_index).sql"
buffer=""

mkdir -p sql_parts  # salva tutto in una cartella dedicata

while IFS= read -r line || [[ -n "$line" ]]; do
    buffer+="$line"$'\n'

    # Se troviamo un punto e virgola a fine riga, consideriamo la statement "completa"
    if [[ "$line" =~ ;[[:space:]]*$ ]]; then
        ((statement_count++))
    fi

    # Quando raggiungiamo il massimo, scriviamo su file
    if (( statement_count >= max_statements_per_file )); then
        echo -n "$buffer" > "sql_parts/${output_file}"
        ((file_index++))
        output_file="${output_prefix}$(printf "%02d" $file_index).sql"
        buffer=""
        statement_count=0
    fi
done < "$input_file"

# Scriviamo l’eventuale contenuto rimanente
if [[ -n "$buffer" ]]; then
    echo -n "$buffer" > "sql_parts/${output_file}"
fi

echo "✅ Fatto! File spezzettati nella cartella 'sql_parts/'"

✅ Vantaggi: Non tronca comandi a metà.

Facile da configurare: puoi cambiare max_statements_per_file per spezzarlo in più o meno parti.

Pulito: ti crea una cartella sql_parts/ con i file parte_00.sql, parte_01.sql, ecc.

🧪 Per eseguirlo:
Salvalo come split_sql.sh, rendilo eseguibile e lancialo:

bash

chmod +x split_sql.sh
./split_sql.sh

Buon divertimento con questo nuovo suggerimento settimanale.

0 commenti

Lascia un Commento

Vuoi partecipare alla discussione?
Sentitevi liberi di contribuire!

Lascia un commento

Il tuo indirizzo email non sarà pubblicato. I campi obbligatori sono contrassegnati *

Contattami se ti servono informazioni relative a Mysql e comandi bash - come dividere un file sql per permettere un import del data base




    Servizi correlati

    Sviluppo di siti internet

    Sviluppo di siti internet

    Nel corso degli anni ho acquisito un’ottima conoscenza dello sviluppo di siti web. Ho lavorato su un’ampia gamma di progetti che mi hanno richiesto di sviluppare diverse competenze. Ho lavorato a piccoli siti web con solo una o due pagine,...

    Altri servizi

    Sviluppo di siti internet

    Sviluppo di siti internet

    Nel corso degli anni ho acquisito un’ottima conoscenza dello sviluppo di siti web. Ho lavorato su un’ampia gamma di progetti che mi hanno richiesto di sviluppare diverse competenze. Ho lavorato a piccoli siti web con solo una o due pagine,...

    Invio email, gestione, creazione

    Invio email, gestione, creazione

    Gli strumenti per l’invio dei messaggi elettronici sono molti e tutti diversi. Alcuni mettono a disposizione molti strumenti, altri meno. Alcuni sono flessibili, altri meno. E comunque può succedere che l’email non arrivi al destinatario per i molteplici motivi: DKIM,...

    Creazione di Landing Page

    Creazione di Landing Page

    La landing page è una pagina specifica che viene raggiunta da un visitatore dopo aver cliccato solitamente su un link o su un annuncio pubblicitario. E’ strutturata in modo da espandere l’argomento trattato nel link o annuncio e per convertire...

    Conoscenza di CMS

    Conoscenza di CMS

    I principali CMS che conosco sono: Wordpress, Drupal, Prestashop, Magento. In questa breve lista li ho messi in ordine di esperienza acquisita.

    Social Network, Google Merchant

    Social Network, Google Merchant

    Come usare i social network in modo da rendere in tuo sito internet interconnesso ad essi. Invio di articoli ai Social Network, invio prodotti attraverso i feed, Google Merchant.

    API

    API

    Uso e gestione delle varie librerie Api esistenti: Google Analytics, Google Maps, Fatture in cloud, Sendowl, Ebay, Amazon, ecc.. Lettura di dati tramite JSON, ecc…

    Moduli e GDPR

    Moduli e GDPR

    GDPR, Privacy policy, cookie policy, moduli per la raccolta dei dati conformi allo standard della privacy policy, analisi e determinazione di quello che serve per essere in regola col regolamento GDPR.

    Tutti i prodotti Google

    Tutti i prodotti Google

    Uso quotidianamente tutti i prodotti Google e ne sperimento le loro potenzialità. Tutti i giorni ho a che fare con Gmail, Gsuite, Google Analytics, Google Tag Manager, Google Search Console, Drive, Youtube, My Business, Maps, Documenti, Fogli (Google Sheet), Presentazioni,...

    Standard di sicurezza

    Standard di sicurezza

    Valutare se un sito è stato bucato o meno, quali standard di sicurezza usare per evitare che questo succeda di nuovo. Applicare il certificato HTTPS alla navigazione e fare in modo che tutte le url vengano redirette in navigazione sicura,...

    Servizi di Hosting

    Servizi di Hosting

    Ti trovi con un sito internet già portato a termine ma che sembra lento, poco navigabile (in termini di velocità) o a volte ti trovi schermate di errore (solitamente di memory limit) che non sai come interpretare, ma che spariscono...

    Gestire un sito web

    Gestire un sito web

    Hai commissionato un sito web, con gallerie fotografiche, slide show, animazioni JQuery e lo lasci invariato per anni? Pensi che il tuo biglietto da visita in internet debba rimanere statico come la brochure che hai fatto stampare e che viene...

    Hai un problema con il web?

    Il tuo sito internet non vuole funzionare? Vuoi rinnovarlo o sistemarlo? Hai un’idea di integrazione ma non sai se è possibile realizzarla o meno?

    Testimonianze

    Ho avuto il piacere di collaborare con Sara in diversi miei progetti. Ho sempre apprezzato la cura e l’impegno con cui prende in carico i suoi compiti. Tra le sue doti migliori spiccano la puntualità e la disponibilità nel risolvere questioni non prettamente attinenti alla sua area…

    Incredibile mente. Non conosce sosta finchè la problematica non viene risolta. Ha trasformato il mio sito vetrina costruito con un CMS desueto in un Ecommerce Drupal + Ubercart. I prodotti sono stati importati nel nuovo CMS attraverso un import e un crawler interamente scritto a mano.

    Stavo avendo problemi con la Web Agency a cui mi ero affidato. Mi avevano promesso un sistema di booking online completamente personalizzato. Ma non riuscivano a portarlo a termine. Per fortuna, ad un certo punto del progetto, è intervenuta Sara, che lo ha portato a termine.

    Skills in cui sono forte

    PHP8
    Html5
    Sviluppo web
    Google Analytics
    API di qualsiasi tipo
    Google Tag Manager
    jQuery
    Css3
    Trasferimento e acquisto domini
    Wordpress
    Drupal

    Recensioni

    Lasciami una recensione

    Pre Footer

    Questo QR Code ti permette di lasciarmi una recensione in maniera facile e veloce.

    Altrimenti qui sotto ti lascio un bottone, con il quale puoi lasciare la recensione direttamente su Google My Business.