Junior SQL Memo

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 8

Aide mémoire

SQL
By junior MEZANGA
chaîne non complète. %
MOTS-CLES COMMENTAIRES désigne plusieurs caractères _
SELECT Opérateur de projection, permettant de désigne un seul caractère
choisir les attributs à afficher quelconque (ou aucun)
Suivi de noms d'attributs ou de * EXEMPLES
(indiquant tous les attributs) Affiche le nom et le prénom de tous les élèves
FROM Suivi d'une ou plusieurs noms de table. La SELECT nomEleve, prenomEleve
présence de plusieurs tables réalise le FROM Eleves;
produit cartésien de ces tables.
WHERE Opérateur de sélection, qui permet de Affiche tous les articles (toutes les colonnes)
choisir des n-uplets selon certains critères SELECT *
(séparés par AND ou OR) FROM Article;
Affiche la désignation de tous les articles de la
Cet opérateur permet aussi de réaliser des commande numéro 1258
jointures, le plus souvent par égalité des deux Critère de jointure!
colonnes de sens identique dans les deux SELECT Designation
tables. FROM Article, Commande WHERE
DISTINCT La clause DISTINCT permet d’éliminer les Article.numArt = Commande.numArt
doublons : si dans le résultat plusieurs n-
uplets sont identiques, un seule sera AND numCom = 1258; Critère de sélection!
conservé.
ORDER BY La clause ORDER BY permet de trier les Afficher toutes les villes où habite au moins un élève
résultats par ordre croissant (ASC) ou
décroissant (DESC). SELECT DISTINCT villeEleve
FROM Eleves;
Le tri peut se faire sur un ou plusieurs Afficher la liste des employés par salaire décroissant
attributs.
SELECT nomEmpl, salaire FROM Employe
L’option ASC est prise par défaut pour ORDER BY salaire DESC;
chacune des expressions citées.
Afficher les élèves par ordre alphabétique du nom
' Les cotes sont obligatoires pour entourer les
puis du prénom
chaînes de caractères et les dates.

SELECT * FROM Eleves


ORDER BY nomEleve, prenomEleve;
Recherche tous les articles de couleur rouges :
IN IN indique si la valeur est égale à l'une de SELECT numArt FROM Article
celles qui se trouvent entre parenthèses WHERE couleur = ‘ROUGE’;
(peuvent être les résultats d'une sousrequête).
On peut utiliser aussi NOT IN (la valeur SELECT numEleve FROM Eleves
n'est égale à aucune de celles de la liste) WHERE dateNaissance = '12/10/1980'; Liste
NULL Indique une valeur non définie (non des employés occupant la fonction de
renseignée). programmeur, analyste ou développeur
Attention, 0 n'est pas une valeur NULL
L'opérateur de comparaison est IS ou IS NOT SELECT nomEmpl, numEmpl FROM Employe
WHERE fonction IN ('programmeur', 'analyste',
LIKE Permet de comparer une valeur avec une developpeur');
Afficher le nom des professeurs dont on ne connaît

"
pas le prénom SELECT nomProf FROM Commercants
FROM Profs WHERE nomCom LIKE 'DE%';
WHERE prenomProf IS NULL;
Recherche tous les noms commençant par DE :
!"
SELECT nomCom, prenomCom, rueCom
UPPER LOWER UPPER transforme tous les caractères d’un SELECT numArt
champ en majuscule. Attention, il faut FROM Article
marquer le nom voulu en majuscule. WHERE UPPER (couleur) = 'BLEU';

LOWER les transforme en minuscule. SELECT NumArt


Attention, il faut marquer le nom voulu en FROM Article
minuscule. WHERE LOWER (couleur) = 'blanc';
BETWEEN Indique si une valeur est comprise entre deux Articles qui coûtent entre 10 et 20 euros inclus.
valeurs. Les extrêmes sont inclus dans Select numArt, nomArt
l'intervalle. FROM Article
WHERE prix BETWEEN 10 AND 20;
AS Permet de renommer un attribut (seulement Affiche la référence et la marge de tous les produits
pour l'affichage de la réponse à la requête) SELECT refProd, (prixVente – prixAchat) AS marge
FROM Produit;
Opérateurs de Permet d'afficher le résultat d'un calcul à Affiche la référence et la marge de tous les produits
calcul (+ - * …) partir d'un ou plusieurs attributs. SELECT refProd, (prixVente – prixAchat) FROM
Produit;
EXISTS Permet de tester l'existence de données dans SELECT nomAttr1
une sous-requête. FROM table1
WHERE EXISTS (SELECT * FROM table2
Si la sous-requête renvoie au moins une ligne, WHERE condition);
même remplie de marqueurs NULL, le
prédicat est vrai. Dans le cas contraire le SELECT nomAttr1
prédicat à la valeur faux. FROM table1
WHERE NOT EXISTS (SELECT * FROM table2
Le prédicat EXISTS peut être combiné avec WHERE condition);
l'opérateur de négation NOT (NOT EXISTS)
pour tester l'absence de données dans la
sousrequête.

OPERATEURS ENSEMBLISTES

UNION Il est possible de faire l’union des résultats La liste des villes où habitent des élèves et des
de deux requêtes. L'union élimine les professeurs : SELECT villeEleve
doublons. FROM Eleves
On a alors A ! B (ou A + B UNION
- A"B). SELECT villeProf
FROM Profs;

"
INTERSECT Il est possible de faire l’intersection des La liste des villes où habitent à la fois des élèves et
résultats de deux requêtes. des professeurs :
On a alors : A " B. SELECT DISTINCT VilleEleve
FROM Eleves
INTERSECT
SELECT DISTINCT VilleProf
FROM Profs;
"
MINUS Il est possible de faire la différence des La liste des villes où habitent seulement des élèves
résultats de deux requêtes. et pas de professeurs :
On a alors : A – B. SELECT DISTINCT VilleEleve
FROM Eleves
MINUS
SELECT DISTINCT VilleProf
FROM Profs;
"
#
"

OPERATEURS D'AGREGATION

COUNT(*) Permet de compter le nombre de lignes Compte le nombre d'élève habitant Cachan et
(nuplets) résultats. appelle le résultat NbCachanais.
SELECT COUNT (*) AS NbCachanais
COUNT(attribut) Permet de compter le nombre de lignes où FROM Eleves
l'attribut indiqué a une valeur non nulle. WHERE villeEleve = 'CACHAN';
SUM(attribut) Permet d'additionner les valeurs d'une Calcul le cumul (la somme) de tous les opérations
colonne numérique pour les n-uplets de débit du compte 1259 le 09/01/04.
sélectionnés. SELECT SUM(montantOperation)
(A ne pas confondre avec COUNT !) FROM Operations
WHERE compte = '1259'
AND date = '09/01/04';

AVG(attribut) Permet d'afficher la moyenne des valeurs Afficher le salaire moyen des analystes
d'une colonne numérique pour les lignes SELECT AVG(salaire)
sélectionnées. FROM Employe
WHERE fonction = 'analyste';
MAX(attribut) Permet d'obtenir la valeur maximale (ou Affiche le salaire de la secrétaire la mieux payée :
MIN(attribut) minimale) d'un attribut pour un ensemble SELECT MAX(salaire)
de n-uplets sélectionnés. FROM Employe
WHERE function = 'secretaire';

GROUP BY, HAVING

GROUP BY Permet de subdiviser la table en groupes, chaque GROUP BY expr1, expr2, …


groupe étant l’ensemble des n-uplets ayant une
valeur commune pour les expressions spécifiées. Affiche le nombre de professeurs par bureau
Les attributs de la clause SELECT doivent alors SELECT bureau, COUNT(nomProf)
être des opérateurs d'agrégation ou des FROM Profs
expressions figurant dans la clause GROUP BY. GROUP BY bureau;
HAVING Sert à préciser quels groupes doivent être HAVING predicat
sélectionnés.
Cette clause se place après GROUP BY et le Affiche les bureaux qui accueillent plus de 2
prédicat ne peut porter que sur des opérateurs professeurs SELECT bureau
d'agrégation ou des expressions figurant dans la FROM Profs
clause GROUP BY. GROUP BY bureau
HAVING COUNT (*) >2;

ANY, ALL

Le critère de recherche employé dans une clause WHERE (l’expression à droite d’un opérateur de comparaison) peut être
le résultat d’un SELECT.
Dans le cas des opérateurs classiques, la sous-interrogation ne doit ramener qu’un n-uplet et un attribut. Elle peut ramener
plusieurs n-uplets à la suite de l’opérateur [NOT] IN, ou à la suite des opérateurs classiques moyennant l’ajout d’un mot
clé (ANY ou ALL).
ANY La comparaison est vraie si elle est vraie pour au … WHERE expr1 = / != / < / > / <= / >= expr2
moins un élément de l’ensemble (donc fausse si ANY (SELECT…);
l’ensemble des n-uplets est vide).

ALL La comparaison est vraie si elle est vraie pour … WHERE expr1 = / != / < / > / <= / >= expr2
tous les éléments de l’ensemble (donc vraie si ALL (SELECT…);
l’ensemble des n-uplets est vide).
$
"
Affiche le bureau qui accueille le plus
de professeurs SELECT bureau
FROM Profs
GROUP BY bureau
HAVING COUNT (*) >= ALL(SELECT COUNT
(*) FROM Profs GROUP BY bureau);

JOINTURES

Jointure C'un produit cartésien entre deux tables suivi d'une SELECT attr1, attr2, …
sélection selon le critère de jointure FROM table1, table2
(n'importe quelle opération de comparaison entre WHERE table1.attr1 = table2.attr2;
un attribut de table1 avec un attribut de table2).
Généralement, le "=" (équi-jointure).

JOINTURES INTERNES

Jointure interne Il s’agit d’une jointure naturelle mettant deux fois SELECT table.expr1, alias.expr2
en jeu la même table. Ceci permet de rassembler FROM table, table alias
venant d’un n-uplet d’une table avec les WHERE table.champ1 = alias.champ2;
informations venant d’un autre n-uplet. A noter
qu’il est obligatoire de spécifier deux fois la table
source dans la clause FROM, en attribuant un alias
à l’une des occurrences.

JOINTURES EXTERNES
LEFT / RIGHT / Lorsqu’on effectue une jointure naturelle sur deux SELECT expr1, expr2, …
FULL tables, il est possible qu’un n-uplet d’une table n’ait FROM table1 LEFT OUTER JOIN table2
OUTER JOIN pas de correspondant dans l’autre. Dans ce cas, le ON table1.champ1 = table2.champ2;
n-uplet en question n’est pas affiché. La jointure
externe permet de résoudre ce problème par l’ajout SELECT expr1, expr2, …
de n-uplets fictifs, qui réalisent la correspondance FROM table1 RIGHT OUTER JOIN
avec les n-uplets de l’autre table n’ayant pas de table2
correspondant réel (LEFT OUTER JOIN ON table1.champ1 = table2.champ2;
correspond à l’ajout de n-uplets fictifs dans table1).

CREATION, MISE A JOUR, DESTRUCTION DE TABLES


ET CONTRAINTES

CREATE TABLE table est le nom donné à la nouvelle table. CREATE TABLE table (col1 type1, col2
col1, col2,… sont les noms des attributs. type1, type2…);
type2,… sont les types des données contenues
dans les attributs.
ALTER TABLE Pour modifier la structure d’une base de données Ajoute les colonnes spécifiées à une table
existante. existante.
ALTER TABLE table ADD (col1 type1,
col2 type2, …);
Modifie la définition des colonnes
spécifiées.
ALTER TABLE table MODIFY (col1
type1, col2 type2…);
Supprime la colonne col.
ALTER TABLE table DROP col;
%
"
DROP TABLE Supprime la définition d’une table et par DROP TABLE table;
conséquent l’ensemble des n-uplets qu’elle
contient.
CONSTRAINT Définit et nomme une contrainte sur un ou CONSTRAINT nomContrainte contrainte
plusieurs attributs.
PRIMARY KEY Indique la clé primaire de la table. PRIMARY KEY (col1, col2,…)
Aucun des attributs de cette clé ne doit avoir une
valeur NULL.
UNIQUE Interdit qu’un attribut (ou la concaténation de UNIQUE (col1, col2,…)
plusieurs attributs) contienne deux valeurs
identiques.
FOREIGN KEY Indique que la concaténation de col1, col2,… est FOREIGN KEY (col1, col2, …)
une clé étrangère faisant référence à la REFERENCES table [(col’1,col’2,…)]
concaténation de col’1, col’2,… de table.

Si col’1,col’2,… sont omises, la clé primaire de


table est prise par défaut.
CHECK Donne une condition devant être vérifiée par un ou CHECK (condition)
plusieurs attributs.

PRINCIPAUX TYPES DE DONNEES

CHAR(taille) Chaînes de caractères de longueur fixe CHAR(3)


VARCHAR(taillemax) Chaînes de caractères de longueur variable VARCHAR(10)
SMALLINT Entier court (sur 16 bits : de -32768 à 32757)
INTEGER Entier long (sur 32 bits : de -2 147 483 648 à
2 147 483 647)
NUMBER(n,[d]) Nombres décimaux qui ont n chiffres dont d Nombre à 5 chiffres avant la virgule et 2
chiffres après la virgule après la virgule : NUMBER(7,2)
REAL Nombre à virgule flottante (faible précision)
FLOAT Nombre à virgule flottante (grande précision)
DOUBLE PRECISION
DATE Date (jour, mois, année) 10/01/2002
TIME Heures, minutes et secondes (les secondes peuvent 10:12:42.85
comporter un certain nombre de décimales)
TIMESTAMP Moment précis : date avec heures, minutes et
secondes (6 chiffres après la virgule, c'est-à-dire en
microsecondes)

CREATION, MISE A JOUR, DESTRUCTION DE N-UPLETS

INSERT Insère un nouvel n-uplet dans table. Si (col1, INSERT INTO table [(col1, col2,…)]
col2,…) est omis, l’ordre utilisé par défaut est VALUES (val1, val2,…)
celui spécifié lors de la création de la table. A
l’inverse, si cette liste est donnée, les attributs n’y
figurant pas auront la valeur NULL.
UPDATE Modifie les n-uplets de table qui vérifient le UPDATE table SET col1 = expr1, col2 =
prédicat. Si predicat est omis, tous les n-uplets expr2,… WHERE predicat
sont mis à jour.
DELETE Supprime les n-uplets de table qui vérifient le DELETE FROM table WHERE predicat
prédicat. Si predicat est omis, tous les n-uplets
sont supprimés.

VUES

&
"
CREATE VIEW Permet de créer une vue en spécifiant une requête. CREATE VIEW nomVue AS
uneRequeteSelect;
Remarque : il est impossible de modifier le
schéma d’une vue. Il faut alors la supprimer et la CREATE VIEW BureauxProfs
recréer. AS SELECT bureau, COUNT(nomProf)
FROM Profs
GROUP BY bureau;
DROP VIEW Supprime une vue. DROP VIEW nomVue;

GESTION DE PRIVILEGES

GRANT Permet au propriétaire de table de donner à GRANT privilege ON table TO utilisateur


utilisateur des droits d’accès sur celle-ci (droit de [WITH GRANT OPTION]
lecture, de modification, de suppression). Si
l’option WITH GRANT OPTION est spécifiée,
utilisateur pourra à son tour transmettre ces droits.
REVOKE Permet de reprendre un privilège à un utilisateur. REVOKE privilege ON table FROM
utilisateur

MERCI JUNIOR MEZANGA


'"

Vous aimerez peut-être aussi