Ceci est une ancienne révision du document !
−Table des matières
SQLite : une base de données SQL
Pré-requis
Installation
- Installez le paquet sqlite3 ou en ligne de commande :
...@...:~$ sudo apt install sqlite3
Configuration
Utilisation
Avec un client graphique : SQLiteManager
En ligne de commande
- Lancez dans un terminal :
...@...:~ $ sqlite3 SQLite version 3.31.1 2020-01-27 19:55:54 Enter ".help" for usage hints. Connected to a transient in-memory database. Use ".open FILENAME" to reopen on a persistent database.
sqlite>Le prompt change et signale que vous êtes dans le terminal SQlite :
Commandes SQLite
- .help : Lister les commandes :
sqlite> .help .archive ... Manage SQL archives .auth ON|OFF Show authorizer callbacks .backup ?DB? FILE Backup DB (default "main") to FILE .bail on|off Stop after hitting an error. Default OFF .binary on|off Turn binary output on or off. Default OFF .cd DIRECTORY Change the working directory to DIRECTORY .changes on|off Show number of rows changed by SQL .check GLOB Fail if output since .testcase does not match .clone NEWDB Clone data into NEWDB from the existing database .databases List names and files of attached databases .dbconfig ?op? ?val? List or change sqlite3_db_config() options .dbinfo ?DB? Show status information about the database .dump ?TABLE? ... Render all database content as SQL .echo on|off Turn command echo on or off .eqp on|off|full|... Enable or disable automatic EXPLAIN QUERY PLAN .excel Display the output of next command in spreadsheet .exit ?CODE? Exit this program with return-code CODE .expert EXPERIMENTAL. Suggest indexes for queries .explain ?on|off|auto? Change the EXPLAIN formatting mode. Default: auto .filectrl CMD ... Run various sqlite3_file_control() operations .fullschema ?--indent? Show schema and the content of sqlite_stat tables .headers on|off Turn display of headers on or off .help ?-all? ?PATTERN? Show help text for PATTERN .import FILE TABLE Import data from FILE into TABLE .imposter INDEX TABLE Create imposter table TABLE on index INDEX .indexes ?TABLE? Show names of indexes .limit ?LIMIT? ?VAL? Display or change the value of an SQLITE_LIMIT .lint OPTIONS Report potential schema issues. .load FILE ?ENTRY? Load an extension library .log FILE|off Turn logging on or off. FILE can be stderr/stdout .mode MODE ?TABLE? Set output mode .nullvalue STRING Use STRING in place of NULL values .once (-e|-x|FILE) Output for the next SQL command only to FILE .open ?OPTIONS? ?FILE? Close existing database and reopen FILE .output ?FILE? Send output to FILE or stdout if FILE is omitted .parameter CMD ... Manage SQL parameter bindings .print STRING... Print literal STRING .progress N Invoke progress handler after every N opcodes .prompt MAIN CONTINUE Replace the standard prompts .quit Exit this program .read FILE Read input from FILE .recover Recover as much data as possible from corrupt db. .restore ?DB? FILE Restore content of DB (default "main") from FILE .save FILE Write in-memory database into FILE .scanstats on|off Turn sqlite3_stmt_scanstatus() metrics on or off .schema ?PATTERN? Show the CREATE statements matching PATTERN .selftest ?OPTIONS? Run tests defined in the SELFTEST table .separator COL ?ROW? Change the column and row separators .session ?NAME? CMD ... Create or control sessions .sha3sum ... Compute a SHA3 hash of database content .shell CMD ARGS... Run CMD ARGS... in a system shell .show Show the current values for various settings .stats ?on|off? Show stats or turn stats on or off .system CMD ARGS... Run CMD ARGS... in a system shell .tables ?TABLE? List names of tables matching LIKE pattern TABLE .testcase NAME Begin redirecting output to 'testcase-out.txt' .testctrl CMD ... Run various sqlite3_test_control() operations .timeout MS Try opening locked tables for MS milliseconds .timer on|off Turn SQL timer on or off .trace ?OPTIONS? Output each SQL statement as it is run .vfsinfo ?AUX? Information about the top-level VFS .vfslist List all available VFSes .vfsname ?AUX? Print the name of the VFS stack .width NUM1 NUM2 ... Set column widths for "column" mode
- .exit ou .quit : Quitter le programme sqlite
- insert : commande SQL insert pour la table TABLE
- line : Une valeur par ligne
- [list] : Valeurs délimitées par la chaîne de séparation .separator
- tabs : valeurs séparées par des tabulations
- tcl : Liste TCL des éléments
- Afficher le nom des colonnes / Changer l'aspect des colonnes (.mode column) :
- .show Affiche les valeurs actuelles des différents paramètres :
sqlite> .show echo: off eqp: off explain: auto headers: off mode: html nullvalue: "" output: stdout colseparator: "|" rowseparator: "\n" stats: off width: filename: :memory:
- Gestion des bases :
- Lister les bases :
- .databases : Liste les noms et les fichiers des bases de données associées
- .tables ?TABLE? : Liste les noms des tables dans la base courante. Si TABLE est spécifié, ne liste que les tables correspondant au motif TABLE.
- Importer les données d'une table :
- .import FILE TABLE : Importer les données de FILE dans TABLE
- .indices ?TABLE? : Afficher les noms de tous les indices ; si TABLE est spécifiée, n'affiche que les indices correspondant au motif TABLE
- Écrire la sortie des résultats dans un fichier
- .output FILENAME : Envoyer la sortie vers FILENAME
- .output stdout : Envoyer la sortie vers l'écran<cli prompt='> '>sqlite> .output bd.txt sqlite> select * from bd;
- Dumper une table depuis SQLite en format SQL pour sauvegarder la structure et les données sur un disque :
- Pour visualiser dans le terminal le fichier créé :
...@...:~ $ cat bd.txt
sqlite> .quit</cli> </WRAP>
- .dump ?TABLE? … : Dump de la base de données dans un format texte SQL. Si TABLE est spécifié, ne dumpe que les tables correspondant au motif TABLE
Voir le résultat de la commande .dump
sqlite> .dump bd
Rediriger la sortie vers un fichier puis dumper la table depuis SQLite
sqlite> .output bd.sql sqlite> .dump bd
Le résultat n'est plus affiché dans le terminal, mais redirigé vers le fichier bd.sql. Pour le vérifier il suffit d'afficher le contenu du fichier:
sqlite> .quit...@...:~ $ cat bd.sql
Lire directement un fichier dumpé depuis sqlite :
- Tout d'abord effacez la table de la base:
sqlite> drop table bd;
- Dumper une base en format SQL pour sauvegarder sa structure, ses tables et ses données
- Dumper la base :
sqlite3 livres.db .dump > livres.sql
- Récupérer un fichier dumpé pour recréer la base :
- Effacez le fichier original avant de procéder à la récupération de la base :
- Effacer la base originale :
...@...:~ $ rm -r livres.db
- Récuperer la base depuis le fichier de svg :
...@...:~ $ sqlite3 livres.db < livres.sql
- Se connecter à la base< :
...@...:~ $ sqlite3 livres.db
</subnumberlist>
Désinstallation
Voir aussi
- (fr) http://Article
Basé sur « Article » par Auteur.