Outils pour utilisateurs

Outils du site


informatique:sql

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
informatique:sql [2011/11/01 11:44]
benoit
informatique:sql [2018/09/06 19:10] (Version actuelle)
Ligne 58: Ligne 58:
 Pour effacer un l'​index nommé **indexuser** : Pour effacer un l'​index nommé **indexuser** :
   ALTER TABLE users DROP INDEX indexuser;   ALTER TABLE users DROP INDEX indexuser;
 +
 +Pour changer l'​encodage de caractères par défaut d'une table : 
 +  ALTER TABLE `ma_table` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;​
  
 === Gestion des colonnes d'une table === === Gestion des colonnes d'une table ===
Ligne 240: Ligne 243:
 ==== Jointures ==== ==== Jointures ====
 === Méthode WHERE === === Méthode WHERE ===
 +
 Pour joindre deux les champs de deux table avec mise en commun des **id** Pour joindre deux les champs de deux table avec mise en commun des **id**
   SELECT articles.nom AS nom_article,​ proprietaires.prenom AS prenom_proprietaire   SELECT articles.nom AS nom_article,​ proprietaires.prenom AS prenom_proprietaire
Ligne 256: Ligne 260:
  
 === Méthode JOIN (recommandée) === === Méthode JOIN (recommandée) ===
-** Jointures ​Internes**+** Jointures ​internes** 
 Pour joindre deux les champs de deux table avec mise en commun des **id** Pour joindre deux les champs de deux table avec mise en commun des **id**
   SELECT articles.nom AS nom_article,​ proprietaires.prenom prenom_proprietaire   SELECT articles.nom AS nom_article,​ proprietaires.prenom prenom_proprietaire
Ligne 266: Ligne 271:
   FROM proprietaires p INNER JOIN articles a    FROM proprietaires p INNER JOIN articles a 
   ON a.id_proprietaire = p.id   ON a.id_proprietaire = p.id
 +
 +**Jointure de 3 tables**
 +
 +  SELECT ​
 +    profiles.*, profiles_times.*,​ times.*
 +  FROM profiles
 +    INNER JOIN profiles_times ON profiles.id = profiles_times.profile_id
 +    INNER JOIN times ON profiles_times.time_id = times.id
 +
 +**Jointure de 4 tables** :!: Attention les Alias AS ont toutes leur importance :
 +  SELECT ​
 +     pr.*, p.*, u.*, lu.*, rh.*
 +  FROM resolved_hosts AS rh
 +    INNER JOIN profiles_routing AS pr ON rh.fqdn = pr.address
 +    INNER JOIN profiles AS p ON pr.profile_id = p.id
 +    INNER JOIN users AS u ON p.id = u.profile_id
 +    INNER JOIN logged_users AS lu ON u.username = lu.user
 +  WHERE rh.timestamp > 1447090110
  
 **Jointures externes** **Jointures externes**
Ligne 271: Ligne 294:
 Le **LEFT JOIN** demande à récupérer tout le contenu de la table de gauche (donc tous les propriétaires) même s'ils n'ont pas d'​équivalence dans la table articles. Le **LEFT JOIN** demande à récupérer tout le contenu de la table de gauche (donc tous les propriétaires) même s'ils n'ont pas d'​équivalence dans la table articles.
   SELECT a.nom nom_article,​ p.prenom prenom_proprietaire   SELECT a.nom nom_article,​ p.prenom prenom_proprietaire
-  FROM proprietaires p +  FROM proprietaires p LEFT JOIN articles a
-  ​LEFT JOIN articles a+
   ON j.ID_proprietaire = p.ID   ON j.ID_proprietaire = p.ID
  
 Le **RIGHT JOIN** demande à récupérer tout le contenu de la table de droite (donc tous les articles) même s'ils n'ont pas d'​équivalence dans la table proprietaires. Le **RIGHT JOIN** demande à récupérer tout le contenu de la table de droite (donc tous les articles) même s'ils n'ont pas d'​équivalence dans la table proprietaires.
   SELECT a.nom nom_article,​ p.prenom prenom_proprietaire   SELECT a.nom nom_article,​ p.prenom prenom_proprietaire
-  FROM proprietaires p +  FROM proprietaires p RIGHT JOIN articles a
-  ​RIGHT JOIN articles a+
   ON j.ID_proprietaire = p.ID   ON j.ID_proprietaire = p.ID
  
informatique/sql.1320144299.txt.gz · Dernière modification: 2018/09/06 18:59 (modification externe)