1/39. I Langage d interrogation et modification des données (DML) I Langage de définition du schéma (DDL)
|
|
- Édouard Durand
- il y a 8 ans
- Total affichages :
Transcription
1 Introduction 1/39 2/39 Introduction Anne-Cécile Caron Licence MIAGE - BDD A partir de l algèbre relationnelle s est construit un langage informatique permettant d interroger les données : SQL Actuellement, le langage SQL comporte plusieurs aspects : I Langage d interrogation et modification des données (DML) I Langage de définition du schéma (DDL) I Aspects système : contrôle d accès, transactions I et depuis la norme SQL3 (1999), des modules stockés, triggers, aspects orientés objets... Aujourd hui nous allons voir le langage d interrogation et modification. Introduction Introduction 3/39 4/39 Objectifs A la fin de ce cours et après avoir fait les TD, TP correspondants vous devez être capables de : I traduire une expression algébrique en requête SQL I traduire une requête du langage naturel vers SQL, requête d interrogation ou de mise à jour I traduire une requête SQL en langage naturel ( que fait cette requête? ) Le schéma exemple Base de données (très simplifiée!) de commandes de produits. CLIENT(num client, nom, prénom, solde) COMMANDE(num commande, date commande,num client) CONTIENT(num commande, num produit, quantité) PRODUIT(num produit, nom, prix unitaire)
2 Introduction 5/39 6/39 Les données instances du schéma exemple Sélection - Projection client: 1 SOPHIE LAURENT DUPONT JULIE 0.00 produit: 1 dentifrice cahier crayons lait eau yop cafe stylo plume commande: contient: produits de prix supérieur à 4 prix unitaire 4(produit) select * where prix_unitaire >= 4 ; 3 crayons stylo plume lait eau cafe 4.75 num produit, nom ( prix unitaire 4(produit)) select num_produit, nom where prix_unitaire >= 4 ; 3 crayons 4 stylo plume 5 lait 6 eau 8 cafe 7/39 8/39 Conditions de sélection I On peut bien sûr utiliser les opérateurs booléens : NOT, AND, OR I Opérateurs de comparaison = <= >=!= <> I Attention, pourtesterl absencedevaleur:is NULL ou son contraire IS NOT NULL I colonne in (v1,v2,...,vk) (on verra ensuite qu on peut remplacer cette liste fixe par une sous-requête) I colonne between exp1 and exp2 select num_produit, nom where prix_unitaire in (2,3) ; num_produit nom cahier Conditions de sélection Pour comparer des chaînes de caractères, on peut utiliser I l opérateur LIKE I ou des expressions régulières à la Unix, opérateur REGEXP_LIKE d Oracle select * where nom like or nom like c% and prix_unitaire<3 ; select * where regexp_like(nom, ^[a-z]{4}$, i ) or regexp_like(nom, ^c, i ) and prix_unitaire<3 num_produit nom prix_unitaire cahier 2 <- commence par c et prix < 3 5 lait 6.5 <-- nom avec 4 carac. 8 cafe 4.75 <-- idem
3 9/39 10 / 39 Entorse au modèle relationnel Le résultat d une requête est un multi-ensemble select nom ; nom DUPONT (3 rows) On dispose de l opérateur distinct pour enlever les résultats identiques. select distinct nom ; nom DUPONT (2 rows) Ordre select * order by nom,prenom ; 3 DUPONT JULIE LAURENT SOPHIE select nom, prenom where solde > 0 order by nom, prenom LAURENT SOPHIE select * order by prix_unitaire desc, nom asc; 4 stylo plume crayons lait eau cafe dentifrice cahier 2 7 yop / / 39 Groupes I par défaut, 1 relation forme 1 groupe I On peut partitionner une relation en utilisant des valeurs d attributs : group by en SQL I On peut appliquer des fonctions sur chaque groupe : I count(a) :comptelenombredevaleursdanslacolonnea. count(distinct A) :nombredevaleurs emdi é r e n t e s. I sum(a) : fait la somme des valeurs de la colonne A. sum(distinct A) :sommedesvaleursdi é r e n t e. s I min(a) :donnelapluspetitevaleurdelacolonnea. I max(a) :donnelaplusgrandevaleurdelacolonnea. I avg(a) :donnelamoyennedesvaleursdelacolonnea. avg(distinct A) :moyennedesvaleursdi é r e n t e. s Fonction de groupe avg(prix unitaire)(produit) select avg(prix_unitaire) ; avg(prix_unitaire) nom,count( )(client) select nom, count(*) group by nom ; nom count(*) DUPONT 1
4 13 / / 39 Condition sur les groupes compter le nombre de produits di érents par commande num commande,count( )(contient) select num_commande,count(*) from contient group by num_commande ; num_commande count(*) count( )>2( num cmde,count( ) (contient)) select num_commande,count(*) from contient group by num_commande having count(*) > 2 ; num_commande count(*) Imbrication de fonctions nombre moyen de produits di érents par commande : select avg(count(*)) as nb_moyen_cmdes from contient group by num_commande ; Le résultat a 1 seule ligne, 1 seule colonne de nom NB MOYEN CMDES : nb_moyen_cmdes Remarque : dans cette requête, on a utilisé AS pour renommer une colonne. 15 / / 39 Plusieurs relations Pour l instant, les requêtes données en exemples utilisent 1 seule relation. Il existe des opérateurs binaires, qui permettent d utiliser plusieurs relations : I produit cartésien et jointure(s) I union, intersection, di é r e n c e Produit cartésien Exemple : client produit cette requête n a pas beaucoup de sens! I SQL1 : select *,produit ; I SQL2 : select * CROSS JOIN produit ; 1 SOPHIE dentifrice LAURENT dentifrice DUPONT JULIE dentifrice SOPHIE cahier 2 2 LAURENT cahier 2 3 DUPONT JULIE cahier SOPHIE stylo plume LAURENT stylo plume DUPONT JULIE stylo plume au total CLIENT PRODUIT lignes, i.e. 24 lignes.
5 17 / / 39 Jointure les commandes et les clients qui les ont passées : commande on client I SQL1 : select num_commande, date_commande, nom, prenom from commande, client where commande.num_client = client.num_client ; I SQL2 : select num_commande, date_commande, nom, prenom from commande JOIN client ON commande.num_client = client.num_client ; select num_commande, date_commande, nom, prenom from commande NATURAL JOIN client ; num_commande date_commande nom prenom SOPHIE SOPHIE LAURENT LAURENT Jointure les clients et tous les articles qu ils ont commandés select client.nom, client.prenom, produit.nom, contient.quantite JOIN commande ON client.num_client = commande.num_client JOIN contient ON commande.num_commande = contient.num_commande JOIN produit ON contient.num_produit = produit.num_produit ; nom prenom nom quantite SOPHIE cahier 5 SOPHIE crayons 1 SOPHIE stylo plume 1 SOPHIE lait 1 SOPHIE yop 2 LAURENT lait 1 LAURENT eau 1 LAURENT dentifrice 1 LAURENT cahier 3 LAURENT cafe 2 19 / / 39 Jointure et fonction de groupe les clients et les sommes qu ils ont dépensées select client.nom, client.prenom, sum(quantite*prix_unitaire) as a_depense JOIN commande ON client.num_client = commande.num_client JOIN contient ON commande.num_commande = contient.num_commande JOIN produit ON contient.num_produit = produit.num_produit group by client.num_client, client.nom, client.prenom ; nom prenom a_depense LAURENT 30 SOPHIE Jointure externe I Permet de faire apparaître les lignes d une table qui n ont pas de correspondant dans l autre table lors d une équi-jointure (ou inner join). I variantes : left (outer) join, right (outer) join, full (outer) join. Exemple : tous les produits avec le nombre de commandes (même 0) dans lesquels ils figurent. select produit.num_produit, count(contient.num_commande) left join contient on produit.num_produit = contient.num_produit group by produit.num_produit ; -- ou bien select produit.num_produit, count(contient.num_commande) from contient right join produit on produit.num_produit = contient.num_produit group by produit.num_produit ;
6 Résultat on suppose, juste pour cette requête, que l on a ajouté la ligne (9, sucre,2.50) dans la table PRODUIT num_produit count(contient.num_commande) <-- pas cette ligne si simple jointure 21 / 39 Opérateurs ensemblistes Union nom(produit) [ nom(client) select nom union select nom ; -- remarque : le résultat n est -- pas forcément dans cet ordre nom DUPONT cafe cahier crayons dentifrice eau lait stylo plume yop 22 / 39 Le résultat d une union, intersection ou di érence ne contient pas de doublons. Opérateurs ensemblistes Di é r e n c e nom,prénom (client) select nom,prenom except select nom, prenom natural join commande ; nom prenom DUPONT JULIE nom,prénom (client on commande) cet opérateur s appelle minus sous Oracle 23 / 39 Opérateurs ensemblistes Intersection nom, prix unitaire ( nom like c% (produit)) \ nom, prix unitaire ( prix unitaire 7 (produit)) select nom,prix_unitaire where nom like c% intersect select nom,prix_unitaire where prix_unitaire >= 4 ; nom prix_unitaire crayons 7.5 cafe / 39
7 25 / / 39 Opérateurs ensemblistes L élimination des doublons a un coût, c est pourquoi on peut utiliser une union multi-ensembliste : nom select nom dentifrice union all cahier select nom ; crayons stylo plume lait eau yop cafe DUPONT Sous-requête En SQL, on a la possibilité d imbriquer les requêtes. On peut ainsi trouver une sous requête I pour exprimer une condition, dans la clause WHERE ou HAVING. L expression conditionnelle utilisée va contraindre le type du résultat de la sous requête. I pour représenter une relation, dans la clause FROM. Dans ce cas, la sous-requête aura pour résultat un ensemble de tuples de valeurs. I pour calculer un résultat, dans la clause SELECT. Dans ce cas, la sous-requête aura pour résultat 1 valeur. 27 / / 39 Sous-requête Sous-requête non corrélative : le résultat de la sous-requête est calculé, indépendamment de la requête qui l englobe. Exemple : les clients qui n ont pas passé commande select nom,prenom where num_client not in (select num_client from commande) ; Le résultat de la sous-requête est un ensemble de nombres. nom prenom DUPONT JULIE Opérateurs pour les sous-requêtes I IN teste l appartenance à une relation (NOT IN pour la non-appartenance) I EXISTS teste si la relation est non vide (NOT EXISTS sinon) I UNIQUE teste si la relation est un singleton (NOT UNIQUE sinon) I combiné avec un opérateur de comparaison, I op ANY La comparaison est vraie pour au moins 1 élément de la sous-requête. I op ALL La comparaison est vraie pour tous les éléments de la sous-requête. remarque : IN est équivalent à =ANY et NOT IN est équivalent à <>ALL.
8 29 / / 39 Sous-requête le(s) produit(s) le(s) plus cher(s) select nom,prix_unitaire where prix_unitaire >= all( select prix_unitaire ) ; select nom,prix_unitaire where prix_unitaire = ( select max(prix_unitaire) ) ; Sous-requête les produits qui ne sont pas les moins chers select nom,prix_unitaire where prix_unitaire > any( select prix_unitaire ) ; select nom,prix_unitaire where prix_unitaire > ( select min(prix_unitaire) ) ; Expression conditionnelle de la forme valeur >= all sous-requete. Ici, la sous-requête a pour résultat un ensemble de nombres. nom prix_unitaire stylo plume Expression conditionnelle de la forme valeur = sous-requete. Ici, la sous-requête a pour résultat 1 nombre. nom prix_unitaire stylo plume crayons 7.5 lait 6.5 eau 5.5 cafe 4.75 dentifrice 2.5 cahier 2 tous sauf le Yop qui vaut / / 39 Sous-requête corrélative Produits qui ont fait l objet d au moins 2 commandes. select nom where 1 < (select count(*) from contient where contient.num_produit = produit.num_produit) ; nom cahier lait Expression conditionnelle de la forme valeur < sous-requete. La sous-requête a pour résultat 1 nombre. Ici, on évalue la sous-requête pour chaque ligne de la table PRODUIT, la sous-requête est dépendante de la requête qui l englobe. Pour cet exemple, on peut écrire une requête équivalente, sans sous-requête. Sous-requête corrélative Pour chaque commande, le produit qui a le plus grand prix unitaire. select co.num_commande, p.nom, p.prix_unitaire from commande co join contient c on c.num_commande = co.num_commande join produit p on p.num_produit = c.num_produit where p.prix_unitaire = (select max(prix_unitaire) p2 join contient c2 on c2.num_produit = p2.num_produit where c2.num_commande = c.num_commande) num_commande nom prix_unitaire stylo plume lait lait cafe 4.75
9 33 / / 39 Sous-requête dans la clause SELECT Le nombre de commandes par client. select nom, prenom, (select count(*) from commande co where co.num_client = client.num_client) nb_commandes nom prenom nb_commandes SOPHIE 2 LAURENT 2 DUPONT JULIE 0 Sous-requête dans la clause FROM Les numéro des commandes dans lesquelles il y a (au moins) un produit coûtant plus de 5 euros. select distinct co.num_commande from (select * where prix_unitaire >= 5) p join contient co on co.num_produit = p.num_produit NUM_COMMANDE La sous-requête a pour résultat un ensemble de tuples. Modifications Insert 35 / 39 Modifications Insert 36 / 39 Insertion Insertion - exemple I insertion d un tuple dans une relation d arité p insert into T values (v 1,..., v p ) insert into client values (1,, SOPHIE,500); T est le nom de la table où il faut insérer le tuple (v 1,...,v p ). I Si on veut insérer un tuple dont on ne connaît pas toutes les valeurs des colonnes, on peut préciser pour quelles colonnes on fait l insertion : insert into T (nomcol 1,...,nomcol n ) values (v 1,...,v n ) Dans ce cas, les colonnes absentes prennent la valeur NULL ou une valeur par défaut selon la définition du schéma de la table T. I Il est aussi possible d insérer dans une table le résultat d une requête. La table où l on insère doit avoir un schéma compatible avec le résultat de la requête. insert into T requete insert into client(num_client,nom,prenom) values (3, DUPONT, JULIE ); --> insère la ligne (3, DUPONT, JULIE,0) ici, l attribut solde prend la valeur 0, et non la valeur NULL, car l attribut solde a été défini avec la valeur 0 par défaut. insert into Tbis select * from T ; insert into T3(nom) select nom prenom ;
10 Modifications Delete 37 / 39 Modifications Update 38 / 39 Suppression Modification I On peut supprimer tous les tuples qui satisfont une condition. delete from T where condition I Sans clause where, on supprime tous les tuples de la relation I On peut modifier tous les tuples qui satisfont une condition, en remplaçant la valeur de certaines colonnes update T set col 1 = e 1,...,col p = e p where condition I La condition suit la même syntaxe que pour une requête de sélection. I Exemple : I Par exemple : delete where nom like DUV% ; supprime les tuples (1,, SOPHIE,500) et (2,, LAURENT,500) de la table CLIENT. update client set nom= DUPOND, prenom= JULIETTE where nom= DUPONT ; cette instruction remplace Julie Dupont par Juliette Dupond. I autre exemple : delete where num_produit not in (select num_produit from contient); supprime les produits qui ne sont pas commandés. Modifications Update 39 / 39 Modification - exemples I En l absence de clause where, tous les tuples seront modifiés. l instruction suivante ajoute donc 100 à tous les soldes des clients. update client set solde = solde+100 ; I On veut enlever du solde des clients la somme qui correspond à leurs commandes. La fonction nvl permet de remplacer une valeur NULL par autre chose. Ici, on remplace NULL par 0 dans le cas où un client n a pas passé de commande. update client set solde = solde - (select nvl(sum(prix_unitaire*quantite),0) join contient on contient.num_produit = produit.num_produit join commande on commande.num_commande = contient.num_commande where client.num_client = commande.num_client )
1. Qu'est-ce que SQL?... 2. 2. La maintenance des bases de données... 2. 3. Les manipulations des bases de données... 5
1. Qu'est-ce que SQL?... 2 2. La maintenance des bases de données... 2 2.1 La commande CREATE TABLE... 3 2.2 La commande ALTER TABLE... 4 2.3 La commande CREATE INDEX... 4 3. Les manipulations des bases
Plus en détailCOMMANDES SQL... 2 COMMANDES DE DEFINITION DE DONNEES... 2
SQL Sommaire : COMMANDES SQL... 2 COMMANDES DE DEFINITION DE DONNEES... 2 COMMANDES DE MANIPULATION DE DONNEES... 2 COMMANDES DE CONTROLE TRANSACTIONNEL... 2 COMMANDES DE REQUETE DE DONNEES... 2 COMMANDES
Plus en détailLe langage SQL Rappels
Le langage SQL Rappels Description du thème : Présentation des principales notions nécessaires pour réaliser des requêtes SQL Mots-clés : Niveau : Bases de données relationnelles, Open Office, champs,
Plus en détailLangage SQL : créer et interroger une base
Langage SQL : créer et interroger une base Dans ce chapitre, nous revenons sur les principales requêtes de création de table et d accès aux données. Nous verrons aussi quelques fonctions d agrégation (MAX,
Plus en détailSQL Historique 1982 1986 1992
SQL Historique 1950-1960: gestion par simple fichier texte 1960: COBOL (début de notion de base de données) 1968: premier produit de sgbdr structuré (IBM -> IDMS) 1970-74: élaboration de l'outil d'analyse
Plus en détailTD n 10 : Ma première Base de Données
TD n 10 : Ma première Base de Données 4 heures Rédigé par Pascal Delahaye 11 mars 2015 Le but de ce TD est de découvrirles principales fonctions d OpenOffice Base, le systèmede gestion de bases de données
Plus en détailBases de données relationnelles
Bases de données relationnelles Système de Gestion de Bases de Données Une base de données est un ensemble de données mémorisé par un ordinateur, organisé selon un modèle et accessible à de nombreuses
Plus en détailBases de Données relationnelles et leurs systèmes de Gestion
III.1- Définition de schémas Bases de Données relationnelles et leurs systèmes de Gestion RAPPELS Contraintes d intégrité sous Oracle Notion de vue Typage des attributs Contrainte d intégrité Intra-relation
Plus en détail14/04/2014. un ensemble d'informations sur un sujet : exhaustif, non redondant, structuré, persistant. Gaëlle PERRIN SID2 Grenoble.
Gaëlle PERRIN SID2 Grenoble Le 10/04/2014 Base de Données (BD) : une grande quantité de données, centralisées ou non, servant pour les besoins d'une ou plusieurs applications, interrogeables et modifiables
Plus en détailLangage SQL (1) 4 septembre 2007. IUT Orléans. Introduction Le langage SQL : données Le langage SQL : requêtes
Langage SQL (1) Sébastien Limet Denys Duchier IUT Orléans 4 septembre 2007 Notions de base qu est-ce qu une base de données? SGBD différents type de bases de données quelques systèmes existants Définition
Plus en détailCours SQL. Base du langage SQL et des bases de données
Cours SQL Base du langage SQL et des bases de données Auteur Tony Archambeau Site web http://sql.sh Date 24 mai 2014 Licence Mis à disposition selon les termes de la licence Creative Commons Attribution
Plus en détailIntroduction au Système de Gestion de Base de Données et aux Base de Données
Introduction au Système de Gestion de Base de Données et aux Base de Données Formation «Gestion des données scientifiques : stockage et consultation en utilisant des bases de données» 24 au 27 /06/08 Dernière
Plus en détailPlan. Bases de Données. Sources des transparents. Bases de SQL. L3 Info. Chapitre 4 : SQL LDD Le langage de manipulation de données : LMD
Plan Bases de Données L3 Info Céline Rouveirol 2010-2011 Bases de Données 1 / 77 Sources des transparents Bases de Données 2 / 77 Bases de SQL - M.P. Dorville/F. Goasdoué, LRI, Université Paris Sud - V.
Plus en détail16H Cours / 18H TD / 20H TP
INTRODUCTION AUX BASES DE DONNEES 16H Cours / 18H TD / 20H TP 1. INTRODUCTION Des Fichiers aux Bases de Données 2. SYSTEME DE GESTION DE BASE DE DONNEES 2.1. INTRODUCTION AUX SYSTEMES DE GESTION DE BASES
Plus en détailLe Langage SQL version Oracle
Université de Manouba École Supérieure d Économie Numérique Département des Technologies des Systèmes d Information Le Langage SQL version Oracle Document version 1.1 Mohamed Anis BACH TOBJI anis.bach@isg.rnu.tn
Plus en détailTD : Requêtes SQL (BDR.TD2-1) INSA 3IF 2008-2009
TD : Requêtes SQL (BDR.TD2-1) INSA 3IF 2008-2009 Loïc Maisonnasse 1 Objectif Ce TD a pour objectif de vous familiariser avec le langage de requêtes SQL. Et de vous apprendre à écrire des requêtes SQL pour
Plus en détailECR_DESCRIPTION CHAR(80), ECR_MONTANT NUMBER(10,2) NOT NULL, ECR_SENS CHAR(1) NOT NULL) ;
RÈGLES A SUIVRE POUR OPTIMISER LES REQUÊTES SQL Le but de ce rapport est d énumérer quelques règles pratiques à appliquer dans l élaboration des requêtes. Il permettra de comprendre pourquoi certaines
Plus en détail1 Introduction et installation
TP d introduction aux bases de données 1 TP d introduction aux bases de données Le but de ce TP est d apprendre à manipuler des bases de données. Dans le cadre du programme d informatique pour tous, on
Plus en détailNFA 008. Introduction à NoSQL et MongoDB 25/05/2013
NFA 008 Introduction à NoSQL et MongoDB 25/05/2013 1 NoSQL, c'est à dire? Les bases de données NoSQL restent des bases de données mais on met l'accent sur L'aspect NON-relationnel L'architecture distribuée
Plus en détailLes bases de données
Les bases de données Introduction aux fonctions de tableur et logiciels ou langages spécialisés (MS-Access, Base, SQL ) Yves Roggeman Boulevard du Triomphe CP 212 B-1050 Bruxelles (Belgium) Idée intuitive
Plus en détailPlan Général Prévisionnel (1/2) (non contractuel) Internet et Outils L1/IO2 2006-2007 S2-IO2 Bases de données: Jointures, Transactions
Général Prévisionnel (1/2) (non contractuel) Internet et Outils L1/IO2 2006-2007 S2-IO2 Bases de données: Jointures, Cours Internet et Outils: [1/12] Intro, Internet, Web, XHTML (2H) [2/12] XHTML(2H) [3/12]
Plus en détailFileMaker 13. Guide de référence SQL
FileMaker 13 Guide de référence SQL 2013 FileMaker, Inc. Tous droits réservés. FileMaker, Inc. 5201 Patrick Henry Drive Santa Clara, Californie 95054 FileMaker et Bento sont des marques commerciales de
Plus en détailSystèmes de Gestion de Bases de Données
Systèmes de Gestion de Bases de Données Luiz Angelo STEFFENEL DUT Informatique 2ème année IUT Nancy Charlemagne Vues Vue : une table virtuelle de la base de données dont le contenu est défini par une requête
Plus en détailDurée : 4 heures Le sujet se présente sous la forme de deux dossiers indépendants
ÉPREUVE E5 : ANALYSE DE GESTION ET ORGANISATION DU SYSTÈME D INFORMATION Durée : 4 heures Le sujet se présente sous la forme de deux dossiers indépendants Page de garde... p 1 Présentation de l entreprise...
Plus en détailCours 4 : Agrégats et GROUP BY
Cours 4 : Agrégats et GROUP BY Agrégat Fonction qui effectue un calcul sur l ensemble des valeurs d un attribut pour un groupe de lignes Utilisation dans une clause SELECT ou dans une clause HAVING 3 types
Plus en détailBases de données cours 4 Construction de requêtes en SQL. Catalin Dima
Bases de données cours 4 Construction de requêtes en SQL Catalin Dima Requêtes SQL et langage naturel Énoncés en langage naturel. Traduction en SQL? Correspondance entre syntagmes/phrases et opérations
Plus en détail1. LA GESTION DES BASES DE DONNEES RELATIONNELLES
Dossier G11 - Interroger une base de données La base de données Facturation contient tout un ensemble d'informations concernant la facturation de la SAFPB (société anonyme de fabrication de produits de
Plus en détailBTS/CGO P10 SYSTEME INFORMATION Année 2012-2013
BTS/CGO P10 SYSTEME INFORMATION Année 2012-2013 TS2 CGO 7 mars 2013 2 heures Aucun document autorisé Calculatrice autorisée Nota : Il vous est demandé d apporter un soin particulier à la présentation de
Plus en détailSQL sous SqlServer OLIVIER D. DEHECQ Olivier http://www.entraide-info.fr 0
2013 SQL sous SqlServer OLIVIER D. DEHECQ Olivier http://www.entraide-info.fr 0 Table des matières Signalétique... 2 1 Les bases du SQL... 3 2 SQL server... 6 2 Références des exercices...21 DEHECQ Olivier
Plus en détailCours: Les Jointures 1
Bases de Données Avancées Module A IUT Lumière, License CE-STAT 2006-2007 Pierre Parrend Cours: Les Jointures 1 Plan Table of Contents Principe...1 Example...1 Types de Jointures...2 Définitions et examples...2
Plus en détailLes bases fondamentales du langage Transact SQL
Les bases fondamentales du langage Transact SQL Version 1.0 Grégory CASANOVA James RAVAILLE http://blogs.dotnet-france.com/jamesr 2 Les bases fondamentales du langage Transact SQL Sommaire 1 Introduction...
Plus en détailFORMATION A L UTILISATION DE PMB QUELQUES NOTIONS DE SQL
FORMATION A L UTILISATION DE PMB QUELQUES NOTIONS DE SQL Cette création est mise à disposition selon le Contrat Paternité-Pas d'utilisation Commerciale-Partage des Conditions Initiales à l'identique 2.0
Plus en détailTP base de données SQLite. 1 Différents choix possibles et choix de SQLite : 2 Définir une base de donnée avec SQLite Manager
TP base de données SQLite 1 Différents choix possibles et choix de SQLite : La plupart des logiciels de gestion de base de données fonctionnent à l aide d un serveur. Ils demandent donc une installation
Plus en détailIntroduction aux Bases de Données 2004/2005
Introduction aux Bases de Données 2004/2005 Chapitre 6: Le langage SQL Ecole Nationale Supérieur de Physique de Strasbourg Christian Wolf christian.wolf@ensps.u-strasbg.fr 6.1 Stockage physique Film numfil
Plus en détailLe langage SQL pour Oracle - partie 1 : SQL comme LDD
Le langage SQL pour Oracle - partie 1 : SQL comme LDD 1 SQL : Introduction SQL : Structured Query Langage langage de gestion de bases de donn ees relationnelles pour Définir les données (LDD) interroger
Plus en détailOptimisation SQL. Quelques règles de bases
Optimisation SQL Quelques règles de bases Optimisation des ordres SQL Page 2 1. QUELQUES RÈGLES DE BASE POUR DES ORDRES SQL OPTIMISÉS...3 1.1 INTRODUCTION...3 1.2 L OPTIMISEUR ORACLE...3 1.3 OPTIMISEUR
Plus en détailLe Langage De Description De Données(LDD)
Base de données Le Langage De Description De Données(LDD) Créer des tables Décrire les différents types de données utilisables pour les définitions de colonne Modifier la définition des tables Supprimer,
Plus en détailVincent Augusto 2010-2011
le des Systèmes Vincent Augusto École Nationale Supérieure des Mines de Saint-Étienne 2010-2011 Un 1/73 le des Un 2/73 1 2 3 4 le 5 6 7 8 Un le des Un 3/73 Contenu du cours : Techniques pour l analyse
Plus en détailISC21-1 --- Système d Information Architecture et Administration d un SGBD Compléments SQL
ISC21-1 --- Système d Information Architecture et Administration d un SGBD Compléments SQL Jean-Marie Pécatte jean-marie.pecatte@iut-tlse3.fr 16 novembre 2006 ISIS - Jean-Marie PECATTE 1 Valeur de clé
Plus en détailPartie I : Créer la base de données. Année universitaire 2008/2009 Master 1 SIIO Projet Introduction au Décisionnel, Oracle
Année universitaire 2008/2009 Master 1 SIIO Projet Introduction au Décisionnel, Oracle Ce projet comporte trois parties sur les thèmes suivants : création de base de donnée, requêtes SQL, mise en œuvre
Plus en détailSystème de Gestion de Bases de Données Relationnelles. MySQL. Youssef CHAHIR
Système de Gestion de Bases de Données Relationnelles MySQL Youssef CHAHIR 1 PLAN Introduction Démarrer MySQL Syntaxe de MySQL Types des attributs Identificateurs Effectuer des requêtes Fonctions de MySQL
Plus en détailPROJET 1 : BASE DE DONNÉES REPARTIES
PROJET 1 : BASE DE DONNÉES REPARTIES GESTION D UNE BANQUE Elèves : David Bréchet Frédéric Jacot Charles Secrétan DONNÉES DU PROJET SSC - Bases de Données II Laboratoire de Bases de Données BD réparties
Plus en détailPHP 5. La base de données MySql. A. Belaïd 1
PHP 5 La base de données MySql A. Belaïd 1 Base de données C est quoi une base de données? Une base de données contient une ou plusieurs tables, chaque table ayant un ou plusieurs enregistrements Exemple
Plus en détailSQL Serveur 2012+ Programme de formation. France Belgique Suisse - Canada. Formez vos salariés pour optimiser la productivité de votre entreprise
SQL Serveur 2012+ Programme de formation France Belgique Suisse - Canada Microsoft Partner Formez vos salariés pour optimiser la productivité de votre entreprise Dernière mise à jour le : Avril 2014 Des
Plus en détailA QUOI SERVENT LES BASES DE DONNÉES?
BASE DE DONNÉES OBJET Virginie Sans virginie.sans@irisa.fr A QUOI SERVENT LES BASES DE DONNÉES? Stockage des informations : sur un support informatique pendant une longue période de taille importante accès
Plus en détailTP Contraintes - Triggers
TP Contraintes - Triggers 1. Préambule Oracle est accessible sur le serveur Venus et vous êtes autorisés à accéder à une instance licence. Vous utiliserez l interface d accés SQL*Plus qui permet l exécution
Plus en détailOlivier Mondet http://unidentified-one.net
T-GSI Ch.4 Le Langage SQL LDD, LCD Cet exercice guidé reprend le plan suivis lors de l intervention de formation faite pour l académie de Versailles. L objectif principal visait en la présentation du langage
Plus en détailLaboratoires de bases de données. Laboratoire n 6. Programmation SQL. par Danièle BAYERS et Louis SWINNEN
Département Informatique Laboratoires de bases de données Laboratoire n 6 Programmation SQL par Danièle BAYERS et Louis SWINNEN Ce document est disponible sous licence Creative Commons indiquant qu il
Plus en détailDurée : 4 heures coefficient : 4 Le sujet se présente sous la forme de deux dossiers indépendants
ÉPREUVE E5 : ANALYSE DE GESTION ET ORGANISATION DU SYSTÈME D INFORMATION Durée : 4 heures coefficient : 4 Le sujet se présente sous la forme de deux dossiers indépendants Page de garde... p 1 Présentation
Plus en détailBases de données Cours 4 : Le langage SQL pour ORACLE
Cours 4 : Le langage SQL pour ORACLE POLYTECH Université d Aix-Marseille odile.papini@univ-amu.fr http://odile.papini.perso.esil.univmed.fr/sources/bd.html Plan du cours 1 Introduction 2 Identificateurs
Plus en détailINSTITUT NATIONAL DES TELECOMMUNICATIONS CONTROLE DES CONNAISSANCES. 2. Les questions sont indépendantes les unes des autres.
INSTITUT NATIONAL DES TELECOMMUNICATIONS CONTROLE DES CONNAISSANCES Durée : 1h30 Date : 17/05/2006 Coordonnateurs : Amel Bouzeghoub et Bruno Defude Documents autorisés : ceux distribués en cours Avertissements
Plus en détailExemple accessible via une interface Web. Bases de données et systèmes de gestion de bases de données. Généralités. Définitions
Exemple accessible via une interface Web Une base de données consultable en ligne : Bases de données et systèmes de gestion de bases de données The Trans-atlantic slave trade database: http://www.slavevoyages.org/tast/index.faces
Plus en détailCREATION WEB DYNAMIQUE
CREATION WEB DYNAMIQUE IV ) MySQL IV-1 ) Introduction MYSQL dérive directement de SQL (Structured Query Language) qui est un langage de requêtes vers les bases de données relationnelles. Le serveur de
Plus en détailMySQL / SQL EXEMPLES
MySQL_exemples_janv04_mpT EXEMPLES 1 MySQL / SQL EXEMPLES Typologie du langage Il est possible d'inclure des requêtes SQL dans un programme écrit dans un autre langage (en langage C par exemple), ainsi
Plus en détail1. Base de données SQLite
Dans ce TP, nous allons voir comment créer et utiliser une base de données SQL locale pour stocker les informations. La semaine prochaine, ça sera avec un WebService. On repart de l application AvosAvis
Plus en détail1 Modélisation d une base de données pour une société de bourse
IN306 : Corrigé SID Christophe Garion 18 octobre 2010 Ce document est un corrigé succinct de l examen du module IN306. 1 Modélisation d une base de données pour une société de bourse Une
Plus en détailComprendre les bases de données
Comprendre les bases de données Auteur : Hervé LEFEBVRE 9 mars 2002 Version compilée des articles parus sur , ce document reprends l introduction à Postgresql
Plus en détailTP3 : Creation de tables 1 seance
Universite de Versailles IUT de Velizy - Algorithmique 2005/2006 TP3 : Creation de tables 1 seance Objectif : Creation et modication de tables dans une base de donnees. Avant de commencer ce TP, terminer
Plus en détailDevoir Data WareHouse
Université Paris XIII Institut Galilée Master 2-EID BENSI Ahmed CHARIFOU Evelyne Devoir Data WareHouse Optimisation, Transformation et Mise à jour utilisées par un ETL Mr R. NEFOUSSI Année 2007-2008 FICHE
Plus en détailTP Bases de données réparties
page 1 TP Bases de données réparties requêtes réparties Version corrigée Auteur : Hubert Naacke, révision 5 mars 2003 Mots-clés: bases de données réparties, fragmentation, schéma de placement, lien, jointure
Plus en détailBases de données. Yamine AIT AMEUR. INPT-ENSEEIHT DIMA 2 Rue Charles Camichel 31071 Toulouse Cedex 7
Bases de données Yamine AIT AMEUR INPT-ENSEEIHT DIMA 2 Rue Charles Camichel 31071 Toulouse Cedex 7 Première partie Introduction 1 Généralités et notions de base Première partie Introduction 1 Généralités
Plus en détailModule Administration BD Chapitre 1 : Surcouche procédurale dans les SGBDS
Module Administration BD Chapitre 1 : Surcouche procédurale dans les SGBDS 1. Introduction Nous allons aborder la notion de surcouche procédurale au sein des SGBDS relationnels tels que Oracle (PLSQL)
Plus en détailA QUOI SERVENT LES BASES DE DONNÉES?
BASE DE DONNÉES OBJET Virginie Sans virginie.sans@irisa.fr A QUOI SERVENT LES BASES DE DONNÉES? Stockage des informations : sur un support informatique pendant une longue période de taille importante accès
Plus en détailTP 8: LES OPERATEURS ENSEMBLISTES
TP 8: LES OPERATEURS ENSEMBLISTES OBJECTIFS : Apprendre la création des requêtes avec les opérateurs ensemblistes: MINUS, UNION et INTERSECT. Partie I: Présentation Un opérateur d'ensemble combine le résultat
Plus en détailBases de données et sites WEB
Bases de données et sites WEB Cours2 : Sécurité et contrôles d accès Anne Doucet 1 Authentification Autorisation Privilèges Rôles Profils Limitations de ressources Plan Audit Contrôle d accès via les vues
Plus en détailStructured Query Language
Informatique S6 3A Structured Query Language PostgreSQL Alexis NEDELEC LISYC EA 3883 UBO-ENIB-ENSIETA Centre Européen de Réalité Virtuelle Ecole Nationale d Ingénieurs de Brest enib c 2007 nedelec@enib.fr
Plus en détailLes Triggers SQL. Didier DONSEZ. Université de Valenciennes Institut des Sciences et Techniques de Valenciennes donsez@univ-valenciennes.
Les Triggers SQL Didier DONSEZ Université de Valenciennes Institut des Sciences et Techniques de Valenciennes donsez@univ-valenciennes.fr 1 Sommaire Motivations Trigger Ordre Trigger Ligne Condition Trigger
Plus en détailLE LANGAGE SQL2 1. INTRODUCTION
LE LANGAGE SQL2 1. INTRODUCTION Les serveurs de données relationnels présentent aujourd hui une interface externe sous forme d un langage de recherche et mise à jour, permettant de spécifier les ensembles
Plus en détailEncryptions, compression et partitionnement des données
Encryptions, compression et partitionnement des données Version 1.0 Grégory CASANOVA 2 Compression, encryption et partitionnement des données Sommaire 1 Introduction... 3 2 Encryption transparente des
Plus en détailLangage propre à Oracle basé sur ADA. Offre une extension procédurale à SQL
Cours PL/SQL Langage propre à Oracle basé sur ADA Offre une extension procédurale à SQL PL/SQL permet d utiliser un sous-ensemble du langage SQL des variables, des boucles, des alternatives, des gestions
Plus en détailOpenPaaS Le réseau social d'entreprise
OpenPaaS Le réseau social d'entreprise Spécification des API datastore SP L2.3.1 Diffusion : Institut MinesTélécom, Télécom SudParis 1 / 12 1OpenPaaS DataBase API : ODBAPI...3 1.1Comparaison des concepts...3
Plus en détailBases de données cours 1
Bases de données cours 1 Introduction Catalin Dima Objectifs du cours Modèle relationnel et logique des bases de données. Langage SQL. Conception de bases de données. SQL et PHP. Cours essentiel pour votre
Plus en détailHistorisation des données
Historisation des données Partie 1 : mode colonne par Frédéric Brouard, alias SQLpro MVP SQL Server Expert langage SQL, SGBDR, modélisation de données Auteur de : SQLpro http://sqlpro.developpez.com/ "SQL",
Plus en détailLes BASES de DONNEES dans WampServer
Les BASES de DONNEES dans WampServer 1 Définitions Générales Une base de données (BDD) permet d'enregistrer, de stocker, de ranger des données de façon organisée et hiérarchisée. SQL est le langage qui
Plus en détailQuelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)
Quelques patterns pour la persistance des objets avec DAO Ce cours présente des modèles de conception utilisés pour effectuer la persistance des objets Université de Nice Sophia-Antipolis Version 1.4 30/8/07
Plus en détailQuelques aspects du Relationnel-Objet du SGBD Oracle
Département informatique de l IUT (de l université) de Bordeaux Cours de Bases de Données : présentation partielle d un SGBD RO 12 août 2015 Olivier Guibert Quelques aspects du Relationnel-Objet du SGBD
Plus en détailPartie 0 : Gestion des tablespace et des utilisateurs... 3
Sommaire Partie 0 : Gestion des tablespace et des utilisateurs... 3 1- Créer deux TableSpaces votre_nom-tbs et Votre_nom-TempTBS :... 3 2. Créer un utilisateur qui porte votre nom :... 3 3. Attribuer à
Plus en détailCours Bases de données 2ème année IUT
Cours Bases de données 2ème année IUT Cours 12 : Concurrence d accès Anne Vilnat http://www.limsi.fr/individu/anne/cours Plan 1 Accès concurrents Définitions Verrous Collisions Niveaux de cohérence Blocage
Plus en détailIntégrité des données
. Contraintes d intégrité : Définition et objectif Intégrité des données Définition des contraintes Vérification des contraintes Contrainte d'intégrité : propriété sémantique que doivent respecter les
Plus en détailBases de données et sites WEB Licence d informatique LI345
Bases de données et sites WEB Licence d informatique LI345 Anne Doucet Anne.Doucet@lip6.fr http://www-bd.lip6.fr/ens/li345-2013/index.php/lescours 1 Contenu Transactions en pratique Modèle relationnel-objet
Plus en détailCours Bases de données 2ème année IUT
Cours Bases de données 2ème année IUT Cours Bilan : Des vues à PL/SQL corrigé Anne Vilnat http://www.limsi.fr/individu/anne/cours Plan 1 Cas exemple 2 Les tables... 3 Vues et index 4 Privilèges 5 Fonctions
Plus en détailIntroduction aux SGBDR
1 Introduction aux SGBDR Pour optimiser une base Oracle, il est important d avoir une idée de la manière dont elle fonctionne. La connaissance des éléments sous-jacents à son fonctionnement permet de mieux
Plus en détailINTRODUCTION AU DATA MINING
INTRODUCTION AU DATA MINING 6 séances de 3 heures mai-juin 2006 EPF - 4 ème année - Option Ingénierie d Affaires et de Projets Bertrand LIAUDET TP DE DATA MINING Le TP et le projet consisteront à mettre
Plus en détailMODE OPERATOIRE OPENOFFICE BASE
MODE OPERATOIRE OPENOFFICE BASE Openoffice Base est un SGBDR : Système de Gestion de Base de Données Relationnelle. L un des principaux atouts de ce logiciel est de pouvoir gérer de façon efficace et rapide
Plus en détailSQL pour. Oracle 10g. Razvan Bizoï. Tsoft, Groupe Eyrolles, 2006, ISBN : 2-212-12055-9, ISBN 13 : 978-2-212-12055-4
SQL pour Oracle 10g Razvan Bizoï Tsoft, Groupe Eyrolles, 2006, ISBN : 2-212-12055-9, ISBN 13 : 978-2-212-12055-4 CUBE ROLLUP Fonctions de classement Partitionnement GROUPING Module 11 : Les requêtes multi-tables
Plus en détailApplication BdD et JDBC. Introduction 1/28. I Dans tout les cas, une seule problématique. I Quelques alternatives :
ntroduction 1/28 2/28 Anne-Cécile Caron Licence MAGE - Bases de Données 2013-2014 Application base de données Pour le développeur : Quel est l environnement? type de client (mode client serveur, intranet,...)
Plus en détailBases de données élémentaires Maude Manouvrier
Licence MI2E- 1ère année Outils en Informatique Bases de données élémentaires Maude Manouvrier Définitions générales et positionnement du cours dans la formation Vocabulaire relatif aux bases de données
Plus en détailAnnée Universitaire 2009/2010 Session 2 de Printemps
Année Universitaire 2009/2010 Session 2 de Printemps DISVE Licence PARCOURS : CSB4 & CSB6 UE : INF 159, Bases de données Épreuve : INF 159 EX Date : Mardi 22 juin 2010 Heure : 8 heures 30 Durée : 1 heure
Plus en détailCréation et Gestion des tables
Création et Gestion des tables Version 1.0 Z Grégory CASANOVA 2 Sommaire 1 Introduction... 3 2 Pré-requis... 4 3 Les tables... 5 3.1 Les types de données... 5 3.1.1 Les types de données Sql Server... 5
Plus en détailIntégrité sémantique dans les bases de données relationnelles
Intégrité sémantique dans les bases de données relationnelles 1 - Intégrité sémantique Bernard ESPINASSE Professeur à Aix-Marseille Université (AMU Ecole Polytechnique Universitaire de Marseille Fev. 2013
Plus en détailPrésentation du PL/SQL
I Présentation du PL/ Copyright Oracle Corporation, 1998. All rights reserved. Objectifs du Cours A la fin de ce chapitre, vous saurez : Décrire l intéret du PL/ Décrire l utilisation du PL/ pour le développeur
Plus en détailCATALOGUE FORMATIONS 2015. DOMAINE Bases de données
DOMAINE Bases de données Version 1.0 - Octobre 2014 1, 2, 3 juin 2015 1, 2, 3 octobre 2015 CATALOGUE Analyse et conception d une base de données Elaboration de fiches de collecte de données Techniques
Plus en détailNotes de cours : bases de données distribuées et repliquées
Notes de cours : bases de données distribuées et repliquées Loïc Paulevé, Nassim Hadj-Rabia (2009), Pierre Levasseur (2008) Licence professionnelle SIL de Nantes, 2009, version 1 Ces notes ont été élaborées
Plus en détailOLAP : Mondrian + Pentaho. Maguelonne Teisseire Hugo Alatrista Salas hugo.alatrista- salas@teledetec9on.fr Flavien Bouillot
OLAP : Mondrian + Pentaho Maguelonne Teisseire Hugo Alatrista Salas hugo.alatrista- salas@teledetec9on.fr Flavien Bouillot Outils Open Source Mondrian : serveur OLAP JFreeReport : ou9l de «Repor9ng» KeHle
Plus en détailINTRODUCTION : Données structurées et accès simplifié
INTRODUCTION : Données structurées et accès simplifié À l'origine de l'informatique, le stockage d'information se faisait sur cartes perforées. Ces supports pauvres ne permettaient pas de définir la structuration
Plus en détailPratique et administration des systèmes
Université Louis Pasteur Licence Informatique (L2) UFR de Mathématiques et Informatique Année 2007/2008 1 But du TP Pratique et administration des systèmes TP10 : Technologie LAMP Le but de ce TP est de
Plus en détailclef primaire ; clef étrangère ; projection ; restriction ; jointure ; SQL ; SELECT ; FROM ; WHERE
Cas Neptune hôtel Base de données et langage SQL Propriété Intitulé long Formation concernée Matière Notions Transversalité Présentation Description Neptune Hôtel. L interrogation d une base de données
Plus en détail