SQLite

SQLite opplæring

SQLite opplæring

Helt siden mennesket begynte å lage systemer, har det alltid vært databaser som tilsvarer dem. Rask videresending til vår tid hvor teknologien har utviklet seg, og nesten alt er nå automatisert. Under utviklingen av systemer og applikasjoner har SQL vært det ledende språket som utviklere bruker for å opprette og administrere databaser. For at SQL skal fungere skikkelig, trenger den en motor. Denne motoren er deretter ansvarlig for håndtering av operasjoner og transaksjoner i hele databasen.

Hva er SQLite?

SQLite er en rask og enkel open source SQL-motor. Mens denne motoren kan ha andre forvekslet med komplette RDBMS-er som Postgres og MySQL, er SQLite annerledes og utfører på topp under visse forhold. SQLite er et nytt bibliotek som håndhever en serverløs, selvstendig SQL-databasemotor uten oppsett. Siden det ikke trenger konfigurasjon som andre databaser, er det lettere å bruke og installere. I motsetning til andre databaser er det ikke en frittstående prosess. Du kan koble databasen til applikasjonen din, slik at postene den lagrer har tilgang til enten dynamisk eller statisk.

Det har alltid vært en misforståelse om at SQLite bare er for utvikling og testing. Selv om det er et flott verktøy for den jobben, er det ikke bare begrenset til systemtesting. For eksempel kan SQLite håndtere et nettsted som mottar mer enn 100.000 besøk per dag på undersiden. Maksimal størrelsesgrense for SQLite er 140 Terabyte, som er mer enn hva de fleste applikasjoner klokker.

Hvorfor skal du bruke SQLite?

Siden den er skrevet i ANSI-C, er API-en enkel å bruke og ganske grei.


INSTALLASJON

Siden SQLites stolthet kommer fra den overraskende enkle konfigurasjonen, er installasjonsprosessen ganske grei. I denne opplæringen vil vi fokusere mer på Linux enn andre plattformer. I disse dager finner vi at SQLite blir levert med nesten alle versjoner av Linux-operativsystemet. Så før du gidder å installere den, bør du sjekke om installasjonen allerede har funnet sted. For å være sikker, skriv inn dette:

$ sqlite3

Hvis det er riktig installert, bør du se følgende resultat:

SQLite versjon 3.7.15.2 09-01-2013 11:53:05
Tast inn ".hjelp "for instruksjoner
Skriv inn SQL-setninger avsluttet med et ";"
sqlite>

Hvis ikke, betyr det at SQLite ikke har blitt installert på systemet ditt. For å installere kan du;

Gå til den offisielle SQLite-siden og last ned SQLite-autoconf- *.tjære.gz fra seksjonen med kildekodene. Deretter åpner du kommandolinjen og kjører følgende kommando;

$ tar xvfz SQLite-autoconf-3071502.tjære.gz
$ cd SQLite-autoconf-3071502
$./ configure --prefix = / usr / local
$ lage
$ make install

Du kan også bruke følgende metode for å installere:

sudo apt-get oppdatering
sudo apt-get install sqlite3

Begge disse metodene vil gjøre det samme. Du kan bekrefte at installasjonen er fullført ved å kjøre den første testen.


Metakommandoer

Metakommandoer brukes for det meste til administrative operasjoner som å undersøke databaser og definere utdataformater. Det unike med alle disse kommandoene er at de alltid starter med en prikk (.). Her er noen av de vanligste som kommer til nytte over tid.

Kommando Beskrivelse
.dump Dumpdatabase er vanligvis SQL-tekstformat
.vise fram Viser gjeldende innstillinger for forskjellige parametere
.databaser Tilbyr komplette databasenavn og filer
.slutte Avslutter SQLite3-programmet
.bord Vis en liste over alle gjeldende tabeller
.skjema Vis skjema for tabellen
.Overskrift Skjuler eller viser utgangstabelloverskriften
.modus Velg modus for utgangstabellen

Standardkommandoer

Når du arbeider med SQLite, finnes det vanlige kommandoer som brukes til forskjellige aktiviteter i databasen. De blir referert til som standardkommandoer siden de vanligvis er de mest brukte. De er klassifisert i tre grupper på grunn av deres forskjellige funksjoner på tvers av omfanget.

Datadefinisjonsspråk

Den aller første gruppen er kommandoene som er ansvarlige for lagringsstruktur og også metoder for datatilgang fra databasen. De er:

Datamanipuleringsspråk

Dette er kommandoene som vanligvis brukes til å manipulere data i databasen. Datamanipulering inkluderer å legge til, fjerne og endre dataene. I denne delen har vi:

Dataspørsmålsspråk

Den siste typen kommandoer er de som gjør det mulig for brukerne å hente visse data fra databasene. Her har vi bare en:

Det er viktig å merke seg at dette ikke er de eneste kommandoene som SQLite kan støtte. Siden vi er på nybegynnerstadiet, skal vi imidlertid bare utforske disse foreløpig.


Opprette en database

Når du arbeider med SQLite3, brukes kommandoer til å opprette en ny database. I motsetning til andre RDBMS, trenger du ikke ha spesielle privilegier for å gjøre dette. Husk at databasenavnet skal være unikt. Følgende er syntaksen for å opprette en database:

sqlite3 DatabaseName.db

En ny database kalt linuxDB vil bli skrevet som følger

$ sqlite3 linuxDB.db
SQLite versjon 3.21.0 2017-10-24 00:53:05
Tast inn ".hjelp "for instruksjoner
Skriv inn SQL-setninger avsluttet med et ";"
SQLite>

Du kan bekrefte opprettelsen av databasen ved å bruke .kommandoer for databaser.

sqlite>.databaser
seq navnefil
--- --------------- ----------------------
0 hoved / hjem / SQLite / linuxDB.db

Opprette tabeller

Siden tabeller er skjelettet til databasen, er det viktig å vite hvordan du lager dem. For å lage en tabell betyr det at du må navngi tabellen, definere kolonnene og datatypen for hver kolonne. Dette er syntaksen for å lage en tabell.

OPPRETT TABELL databasenavn.tabellnavn (
kolonne1 datatype PRIMÆR NØKKEL (en eller flere kolonner),
kolonne2 datatype,
kolonne3 datatype,
..
columnN datatype
);

I aksjon er dette hvordan en eksempeltabell kalt product_x vil se ut. ID er hovednøkkelen. Du bør alltid huske å spesifisere felt som ikke kan være null.

sqlite> OPPRETT TABELL produkt_x (
ID INT PRIMÆR NØKKEL IKKE NULL,
NAVNTEKST IKKE NULL,
ENHETER INT IKKE NULL,
PRIS INT,
RABATT REALT
);

Slipp bord

Denne kommandoen brukes når utvikleren ønsker å fjerne en tabell sammen med alt innholdet. Du bør alltid være forsiktig når du bruker denne kommandoen, siden når tabellen er slettet, går alle påfølgende data tapt for alltid. Dette er syntaksen:

DROP TABLE database_name.tabellnavn;

sqlite> DROP TABLE product_x;

Endre bord

Denne kommandoen brukes til å redigere innholdet i en tabell uten å måtte dumpe og laste inn dataene på nytt. I SQLite er det bare to operasjoner du kan utføre på et bord med denne kommandoen; endre navn på en tabell og legge til eller fjerne nåværende kolonner.

Dette er syntaksen for å gi nytt navn til en allerede eksisterende tabell og legge til henholdsvis en ny kolonne;

ALTER TABLE database_name.tabellnavn RENAME TIL nytt_tabellnavn;
ALTER TABLE database_name.tabellnavn LEGG TIL KOLONN kolonnedef…;

For eksempel kan en tabell med navnet product_x omdøpes til product_yz, og vi kan legge til en ny kolonne til product_yz i de to linjene med kode nedenfor:

sqlite3> ALTER TABLE product_x
…> RENAME TO product_yz;
sqlite3> ALTER TABLE product_yz
...> LEGG TIL KOLONN produsentnavn TEKST;

Sett inn spørring

INSERT INTO-kommandoen brukes til å legge til datarader i en tabell inne i databasen. Syntaksen for dette er ganske direkte:

INSERT IN TABLE_NAME VALUES (verdi1, verdi2, verdi3,… verdiN);

Kolonne1, kolonne2, ... kolonneN er navnene på kolonnene som tilhører tabellen du vil sette inn data. Det er viktig å spesifisere kolonnenavnet i SQLite når du legger til verdier i alle kolonnene i tabellen.

VELG spørring

SELECT-setningen i SQLite brukes primært til å hente data fra SQLite-databasen og returnere nevnte data i form av et resultatsett. Dette er syntaksen for bruk av SELECT-setningen;

VELG kolonne1, kolonne2, kolonneN FRA tabellnavn;

Fra ovenstående syntaks er kolonne1, kolonne2 ... de respektive feltene i tabellen der du vil hente verdier. Hvis du vil hente alle feltene i den tabellen, bruker du følgende syntaks. Jokertegnet (*) betyr i utgangspunktet 'alle'.

VELG * FRA TABLE_NAME;

OPPDATERINGSSPØRSEL

I en database må poster endres av en eller annen grunn. Anta at en bruker ønsker å endre e-postadressen sin på plattformen din, dette er akkurat kommandoen du trenger for å få denne prosessen til å fungere. Mens vi bruker UPDATE-setningen, må vi også bruke WHERE-setningen for å oppdatere de valgte radene. Hvis ikke, vil du finne at alle radene er oppdatert! Det ville være veldig ille. Dette er syntaksen for å utføre denne operasjonen:

OPPDATER tabellnavn
SET kolonne1 = verdi1, kolonne2 = verdi2… ., kolonneN = verdiN
HVOR [tilstand];

Hvis du har et N antall vilkår som skal oppfylles, kommer AND- eller ELLER-operatørene veldig godt med. Eksempel:

sqlite> OPPDATER produkt_x
…> SET UNITS = 103 WHERE ID = 6;

AND & OR operatørene

Dette er det som kan kalles konjunktive operatører. De brukes til å kompilere flere forhold for å krympe valgte data i et SQLite-miljø. Disse operatørene gjør det mulig for en utvikler å gjøre flere sammenligninger av verdier ved hjelp av forskjellige operatorer på en SQLite-setning.

AND-operatøren er unik siden den tillater brukeren å ha flere forhold i forbindelse med WHERE-setningen. Når du bruker denne operatøren, betraktes vilkåret som sant hvis alle vilkårene er oppfylt. Dette er syntaksen for AND-operatøren.

VELG kolonne1, kolonne2, kolonneN
FRA tabellnavn
WHERE [condition1] AND [condition2]… AND [conditionN];

På baksiden av ting har vi OR-operatøren som også brukes sammen med WHERE-setningen. I motsetning til AND-operatøren, er betingelsen oppfylt hvis en av vilkårene er oppfylt. Syntaksen er ganske enkel.

VELG kolonne1, kolonne2, kolonneN
FRA tabellnavn
WHERE [condition1] OR [condition2]… OR [conditionN]

Kilder og tilleggsinformasjon

http: // linuxgazette.nett / 109 / chirico1.html
http: // www.yolinux.com / TUTORIALS / SQLite.html
https: // www.sitepunkt.no / komme i gang-sqlite3-basic-kommandoer /
https: // www.digitalocean.no / community / tutorials / how-and-when-to-use-sqlite
http: // www.thegeekstuff.no / 2012/09 / sqlite-kommando-eksempler /?utm_source = feedburner

Hvordan bruke AutoKey til å automatisere Linux-spill
AutoKey er et desktopautomatiseringsverktøy for Linux og X11, programmert i Python 3, GTK og Qt. Ved å bruke skript og MACRO-funksjonalitet kan du aut...
Hvordan vise FPS-teller i Linux-spill
Linux-spill fikk et stort press da Valve kunngjorde Linux-støtte for Steam-klient og spillene deres i 2012. Siden den gang har mange AAA- og indiespil...
Hvordan laste ned og spille Sid Meier's Civilization VI på Linux
Introduksjon til spillet Civilization 6 er et moderne syn på det klassiske konseptet som ble introdusert i serien av Age of Empires-spillene. Ideen va...