Sql: Unterschied zwischen den Versionen
Zeile 119: | Zeile 119: | ||
select count(*) from users; | select count(*) from users; | ||
select id, name, email from users where email like '%gmx.de'; | select id, name, email from users where email like '%gmx.de'; | ||
select name | select concat(name, ': ', email) from users; | ||
select min(last_login) from users; | select min(last_login) from users; | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Zeile 126: | Zeile 126: | ||
* Es wird die Anzahl Datensätze von users angezeigt | * Es wird die Anzahl Datensätze von users angezeigt | ||
* Es werden id, name, und email von den Datensätzen angezeigt, deren email gmx.de enthält. '%' ist der universelle Platzhalter (beliebiger String) | * Es werden id, name, und email von den Datensätzen angezeigt, deren email gmx.de enthält. '%' ist der universelle Platzhalter (beliebiger String) | ||
* Es können Zeichenketten mit | * Es können Zeichenketten mit der Funktion concat() zusammengesetzt werden: Eine Ausgabe wäre "Adam: a@gmx.com" | ||
* Es wird der jüngste Eintrag der Spalte last_login angezeigt | * Es wird der jüngste Eintrag der Spalte last_login angezeigt | ||
Version vom 23. Januar 2024, 17:33 Uhr
Links
Zielsetzung
Einführung in die Datenbanksprache Structured Query Language. Damit kann man Datenbanktabellen erstellen, Daten eintragen, ändern, löschen und abfragen.
Es gibt Standards für SQL, der Kurs formuliert die Beispiele im Dialekt von MariaDB (oder MySql).
Relationen (Tabellen)
Die Welt besteht aus Entitäten: materielle und ideelle Dinge, Sachen oder Ideen. Beispiele: Person Farbe Abteilung.
Ist eine Entität unteilbar, wird sie Attribut genannt. Beispiele: Farbe, Identifikationsnummer, Nachname
Eine Relation, auch Datenbanktabelle genannt, ist ein Menge von Datensätzen (auch Zeilen genannt). Jeder Datensatz beschreibt eine normalerweise teilbare Entität.
Jeder Datensatz besteht aus (für jeden Datensatz gleichen) Menge von Attributen, auch Spalten genannt.
In Relationen können beliebig viele Entitäten gespeichert werden.
Beispiel
Eine Adresse ist eine Entität, die aus den Attributen Name, Vorname, Ort, Postleitzahl, Straße und Hausnummer besteht.
Name | Vorname | Ort | PLZ | Straße | Nr |
---|---|---|---|---|---|
Müller | Hans | Berlin | 10122 | Hauptgasse | 10 |
Maier | Ulricke | Augsburg | 80123 | Siemensalee | 3 |
Diese Relation hat 2 Datensätze (Zeilen).
Erstellen einer Relation
Wir legen eine Datei test.sql an:
create table users (
id integer primary key auto_increment,
name varchar(64),
email varchar(255),
password varchar(255),
last_login timestamp
);
- Konvention: Wir vergeben immer eine "technische Id" als Identifikation. Weil alle anderen Attribute können sich evt. ändern.
- Konvention: Tabellennamen sind immer in Mehrzahl.
id integer primary key auto_increment
: Das Attribut "id" ist eine Zahl, die den Benutzer identifiziert, das wird Primärschlüssel genannt. Die Zahl wird automatisch generiert (auto_increment)name varchar(64)
: Das Attribut heißt name, der Datentyp ist eine Zeichenkette mit maximaler Länge 64.last_login timestamp
: Mit diesem Attribut wird der Zeitpunkt (Datum + Uhrzeit) des letzten Logins festgehalten.
SQL-Befehle in Datenbank bringen
mysql -utester -pTopSecret dbtest1 < test.sql
Datentypen
- Texttypen:
- char(<length>) Zeichenkette mit fester Länge. Beispiel deutsche Postleitzahl:
plz char(5)
- text: Variable Zeichenkette bis 65535 Zeichen.
- longtext Variable Zeichenkette bis 4 GByte
- char(<length>): Zeichenkette mit variabler Länge. Beispiel
name varchar(64)
- char(<length>) Zeichenkette mit fester Länge. Beispiel deutsche Postleitzahl:
- Zahltypen:
- decimal(<length>) oder decimal(<length>, <precisision>): Dezimalzahl mit maximaler Länge von <length> und maximal <precisision> Nachkommastellen. Beispiel:
price decimal(13,2)
- float : Gleitpunktzahlen Beispiel:
article_weight float
- integer oder int: eine ganze Zahl. Beispiel:
birth_year int
- decimal(<length>) oder decimal(<length>, <precisision>): Dezimalzahl mit maximaler Länge von <length> und maximal <precisision> Nachkommastellen. Beispiel:
- Datumstypen:
- date: nur Datum. Beispiel:
birthday date
- datetime: Datum und Uhrzeit. Beispiel:
term datetime
- timestamp: Zeitpunkt mit Genauigkeit 1 Sekunde, gilt nur ab 1.1.1970. Beispiel:
created_at timestamp
- date: nur Datum. Beispiel:
- Sonstiges:
- bool: ein Wahrheitswert. Beispiel:
active bool
- bool: ein Wahrheitswert. Beispiel:
Datenbank und Benutzer anlegen
Wie eine Datenbank angelegt wird, hängt vom Datenbanksystem ab.
Wir legen eine MySql-Datenbank "dbtest1" an:
sudo mysqladmin -u root create dbtest1
Wir brauchen noch eine Datenbankbenutzer "tester":
sudo -u root mysql <<EOS
GRANT ALL on dbtest1.* to 'tester'@'localhost' identified by 'TopSecret' with grant option;
EOS
Daten einfügen
insert into users (name, email, last_login) values
('Adam', 'a@gmx.com', '2023-09-27 07:44'),
('Bob', 'b@gmx.de', '2023-09-27 07:44'),
('Charly', 'c@gmx.com', '2023-09-27 07:44'),
('Eve', 'e@gmx.net', '2023-09-28 13:44'),
('Diana', 'd@gmx.de', '2023-09-28 13:44');
- Es muss spezifiziert werden, welche Attribute (Spalten) belegt werden sollen: hier sind es 3 Spalten
- Dann folgt eine Liste von Einträgen.
- Zeichenketten werden in einfache Anführungszeichen gesetzt.
- Ein Datum/Zeitpunkt wird mit der amerikanischen Schreibweise angegeben: <year>-<month>-<day> <hour>:<minute>
Daten ändern
update users set
last_login = NOW(),
password = 'PleaseChange'
where password is null;
- Wir ändern in Tabelle users.
- die Spalte last_login wird mit dem aktuellen Datum belegt.
- das Passwort wird auf 'PleaseChange' gesetzt
- aber nur die Datensätze, in denen noch kein Passwort gesetzt ist.
Daten anzeigen
select * from users;
select id, name, email from users where id in (2, 3);
select count(*) from users;
select id, name, email from users where email like '%gmx.de';
select concat(name, ': ', email) from users;
select min(last_login) from users;
- Es wird alles in der Tabelle users angezeigt.
- Es werden nur die Spalten id, name, und email von den Datensätzen angezeigt, bei denen id den Wert 2 oder 3 hat
- Es wird die Anzahl Datensätze von users angezeigt
- Es werden id, name, und email von den Datensätzen angezeigt, deren email gmx.de enthält. '%' ist der universelle Platzhalter (beliebiger String)
- Es können Zeichenketten mit der Funktion concat() zusammengesetzt werden: Eine Ausgabe wäre "Adam: a@gmx.com"
- Es wird der jüngste Eintrag der Spalte last_login angezeigt
Bezüge zwischen Relationen
Tabelle für Kurse
create table courses (
id integer primary key auto_increment,
name varchar(64),
leader_id integer,
description text
);
- Ein Kurs hat einen Namen, eine Beschreibung und einen Leiter, der ein Verweis auf die Tabelle users ist.
Speichern der Mitglieder
- Beispiel: Eine Kurs kann 2 Teilnehmer haben, aber auch 200, oder ein Online-Kurs auch 2 Millionen.
- Wenn also in der Tabelle courses Platz für alle Teilnehmer sein soll, müssten wir 2 Millionen Attribute anlegen.
- Das geht besser:
- Wir legen eine Tabelle members an. In der können dann problemlos beliebig viele Einträge gespeichert sein.
create table members (
id integer primary key auto_increment,
user_id integer,
course_id integer);
- member bekommt ein Attribut course_id, in dem die Id des Kurses gespeichert wird.
- Wenn wir alle Teilnehmer eines Kurses mit der Id 255 haben wollen, dann fragen wir einfach nach den Datensätzen von members, in denen das Attribut course_id den Wert 255 hat.
select * from members where course_id=255;
Es geht auch noch eleganter: Gib mir alle Teilnehmer des Kurses mit dem Namen "Italienisch für Anfänger":
select * from members where course_id in (select id from courses where name = 'Italienisch für Anfänger');
- Das Datenbanksystem führt zuerst die Unterabfrage
select id from courses where name = 'Italienisch für Anfänger'
aus. - Das Ergebnis ist eine Menge von Ids, im Beispiel die einzelne Id 255.
- Dann wird die Abfrage ausgeführt:
select * from members where course_id in (255)
Joins
Mit Joins können sehr einfach Attribute von kombinierten Relationen angesprochen werden.
Beispiel: Zeige mit alle Namen der Mitglieder des Kurses "Französisch für Anfänger":
SELECT u.name FROM users u
JOIN members m ON m.user_id=u.id
JOIN courses c ON where c.id=m.id
where name = 'Französisch für Anfänger');
Aufgabe
Definiere eine Relation "notes" für Notizen. Attribute: Id, title, body, created at, user_id.