{"id":1102,"date":"2017-12-11T14:25:59","date_gmt":"2017-12-11T12:25:59","guid":{"rendered":"http:\/\/www.lafabriquedecode.com\/blog\/?p=1102"},"modified":"2017-12-11T14:25:59","modified_gmt":"2017-12-11T12:25:59","slug":"le-predicat-sql-exists","status":"publish","type":"post","link":"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/","title":{"rendered":"Le pr\u00e9dicat SQL EXISTS"},"content":{"rendered":"<p>Le mot cl\u00e9 SQL EXISTS est ce que l&rsquo;on appelle un pr\u00e9dicat, il \u00e9value une (sous-)requ\u00eate et dit si elle contient (true) ou non (false) des tuples. Pour travailler avec, nous allons utiliser deux tables au sch\u00e9ma simplissime, clients et commandes, dont voici les extensions, c&rsquo;est \u00e0 dire l&rsquo;ensemble des tuples qu&rsquo;elles contiennent.<\/p>\n<p><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/clients.png\"><img loading=\"lazy\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/clients.png\" alt=\"clients\" width=\"167\" height=\"174\" class=\"alignnone size-full wp-image-1103\" \/><\/a><\/p>\n<p><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/comm.png\"><img loading=\"lazy\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/comm.png\" alt=\"comm\" width=\"173\" height=\"174\" class=\"alignnone size-full wp-image-1104\" srcset=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/comm.png 173w, http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/comm-150x150.png 150w\" sizes=\"(max-width: 173px) 100vw, 173px\" \/><\/a><\/p>\n<p>Pour trouver les noms et pr\u00e9noms des clients qui ont une commande:<\/p>\n<p><code>SELECT nom, prenom FROM clients WHERE EXISTS (select * from commandes)<\/code><\/p>\n<p>Voil\u00e0 le r\u00e9sultat:<br \/>\n<a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete1.png\"><img loading=\"lazy\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete1.png\" alt=\"requete1\" width=\"132\" height=\"125\" class=\"alignnone size-full wp-image-1108\" \/><\/a><\/p>\n<p>Heu&#8230;attendez voir, je fais quoi parmi ces r\u00e9sultats, je n&rsquo;ai pas pass\u00e9 commande ! Que dit en r\u00e9alit\u00e9 notre requ\u00eate ? \u00ab\u00a0Donne-moi le nom et pr\u00e9nom des clients tant qu&rsquo;il EXISTE des commandes\u00a0\u00bb. Il existe 5 commandes, j&rsquo;ai donc 5 clients. <em>Et oui, attention car \u00e0 ce stade, nous n&rsquo;avons absolument pas demand\u00e9 de corr\u00e9lation entre les r\u00e9sultats<\/em>. Faisons-le et notez au passage que nous utilisons <strong>TRUE<\/strong> en lieu et place du joker \u00ab\u00a0*\u00a0\u00bb dans la sous-requ\u00eate:<\/p>\n<p><code>SELECT nom, prenom FROM clients c WHERE EXISTS (SELECT TRUE FROM commandes co  WHERE c.id = co.client_id)<\/code><\/p>\n<p>Voil\u00e0 qui est nettement mieux, vous en conviendrez !<\/p>\n<p><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete2.png\"><img loading=\"lazy\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete2.png\" alt=\"requete2\" width=\"120\" height=\"109\" class=\"alignnone size-full wp-image-1111\" \/><\/a><\/p>\n<p>Alors, vous allez me dire, \u00ab\u00a0Quel est l&rsquo;int\u00e9r\u00eat d&rsquo;utiliser EXISTS, nous sommes en train de faire ni plus ni moins qu&rsquo;une jointure interne\u00a0\u00bb et vous aurez raison. D&rsquo;ailleurs, certaines personnes qui ont grand besoin d&rsquo;une mise \u00e0 jour en SQL s&rsquo;en servent comme \u00ab\u00a0jointure du pauvre\u00a0\u00bb. La grosse diff\u00e9rence, c&rsquo;est que vous ne pouvez pas projeter des attributs potentiellement contenus dans la sous-requ\u00eate, ce qui peut \u00eatre fait avec un JOIN, interne ou externe. Ici nous ne pouvons projeter que <em>nom<\/em> et <em>prenom<\/em>, qui sont des attributs de la table <em>clients<\/em>. Pensez aussi \u00e0 l&rsquo;utilisation des index (utiliser <strong>EXPLAIN<\/strong> !)<\/p>\n<h1>To EXIST or not to EXIST?<\/h1>\n<p>Evidemment, EXISTS a aussi son contraire &#8211; comme NULL &#8211; c&rsquo;est NOT EXISTS.<br \/>\nReprenons la derni\u00e8re requ\u00eate (notez que TRUE est devenu 1)<\/p>\n<p><code>SELECT nom, prenom FROM clients c WHERE NOT EXISTS (SELECT 1 FROM commandes co  WHERE c.id = co.client_id)<\/code><\/p>\n<p>Et hop ! Me voil\u00e0 apparaissant dans les r\u00e9sultats !<br \/>\n<a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete3.png\"><img loading=\"lazy\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete3.png\" alt=\"requete3\" width=\"136\" height=\"47\" class=\"alignnone size-full wp-image-1114\" \/><\/a><\/p>\n<h1>Le pr\u00e9dicat EXISTS sur un UPDATE<\/h1>\n<p>Si je souhaite mettre le montant des commandes pour lesquelles il n&rsquo;existe pas de client \u00e0 1, je ferai:<\/p>\n<p><code>UPDATE commandes AS co<br \/>\nSET montant = 1<br \/>\nWHERE NOT EXISTS (SELECT * FROM clients c  WHERE c.id = co.client_id)<\/code><\/p>\n<p>C&rsquo;est un peu moins d\u00e9licat \u00e0 \u00e9crire qu&rsquo;un UPDATE avec une jointure.<\/p>\n<h1>Le pr\u00e9dicat EXISTS sur un DELETE<\/h1>\n<p>Ce n&rsquo;est gu\u00e8re plus difficile, notez seulement que DELETE n&rsquo;accepte pas nativement l&rsquo;alias (AS), il faut donc mettre commandes en toutes lettres.<\/p>\n<p><code>DELETE FROM commandes<br \/>\nWHERE NOT EXISTS (SELECT * FROM clients c  WHERE c.id = commandes.client_id)<\/code><\/p>\n<h1>Autre exemple<\/h1>\n<p>Alt\u00e9rons notre relation <em>commandes<\/em> pour en faire celle qui suit:<\/p>\n<p><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete4.png\"><img loading=\"lazy\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete4.png\" alt=\"requete4\" width=\"186\" height=\"143\" class=\"alignnone size-full wp-image-1117\" \/><\/a><\/p>\n<p>Et rajoutons une relation <em>produits<\/em> elle aussi tout \u00e0 fait basique:<\/p>\n<p><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete5.png\"><img loading=\"lazy\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/requete5.png\" alt=\"requete5\" width=\"128\" height=\"82\" class=\"alignnone size-full wp-image-1118\" \/><\/a><\/p>\n<p>Maintenant supposons que nous souhaitions trouver le nom des produits de toute commande contenant une \u00e9charpe et qui ne sont pas une \u00e9charpe justement:<\/p>\n<p><code>SELECT p.nom FROM commandes AS co<br \/>\nINNER JOIN produits p ON (p.id = co.produit_id)<br \/>\nWHERE produit_id != 2<br \/>\nAND EXISTS (select * from commandes AS co2 WHERE co.client_id = co2.client_id AND co2.produit_id = 2)<\/code><\/p>\n<p>Nous cherchons les commandes qui contiennent le produit 2 dans la sous-requ\u00eate et nous projetons ceux dont l&rsquo;id n&rsquo;est pas 2.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Le mot cl\u00e9 SQL EXISTS est ce que l&rsquo;on appelle un pr\u00e9dicat, il \u00e9value une (sous-)requ\u00eate et dit si elle contient (true) ou non (false) des tuples. Pour travailler avec, nous allons utiliser deux tables au sch\u00e9ma simplissime, clients et commandes, dont voici les extensions, c&rsquo;est \u00e0 dire l&rsquo;ensemble des tuples qu&rsquo;elles contiennent. Pour trouver [&hellip;]<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0},"categories":[78,2],"tags":[97,6],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v19.6.1 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Le pr\u00e9dicat SQL EXISTS - La Fabrique de code - Tech blog<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/\" \/>\n<meta property=\"og:locale\" content=\"fr_FR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Le pr\u00e9dicat SQL EXISTS - La Fabrique de code - Tech blog\" \/>\n<meta property=\"og:description\" content=\"Le mot cl\u00e9 SQL EXISTS est ce que l&rsquo;on appelle un pr\u00e9dicat, il \u00e9value une (sous-)requ\u00eate et dit si elle contient (true) ou non (false) des tuples. Pour travailler avec, nous allons utiliser deux tables au sch\u00e9ma simplissime, clients et commandes, dont voici les extensions, c&rsquo;est \u00e0 dire l&rsquo;ensemble des tuples qu&rsquo;elles contiennent. Pour trouver [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/\" \/>\n<meta property=\"og:site_name\" content=\"La Fabrique de code - Tech blog\" \/>\n<meta property=\"article:published_time\" content=\"2017-12-11T12:25:59+00:00\" \/>\n<meta property=\"og:image\" content=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/clients.png\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary\" \/>\n<meta name=\"twitter:creator\" content=\"@LaFabrique2Code\" \/>\n<meta name=\"twitter:site\" content=\"@LaFabrique2Code\" \/>\n<meta name=\"twitter:label1\" content=\"\u00c9crit par\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"Dur\u00e9e de lecture estim\u00e9e\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/\",\"url\":\"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/\",\"name\":\"Le pr\u00e9dicat SQL EXISTS - La Fabrique de code - Tech blog\",\"isPartOf\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#website\"},\"datePublished\":\"2017-12-11T12:25:59+00:00\",\"dateModified\":\"2017-12-11T12:25:59+00:00\",\"author\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162\"},\"breadcrumb\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/#breadcrumb\"},\"inLanguage\":\"fr-FR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"http:\/\/www.lafabriquedecode.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Le pr\u00e9dicat SQL EXISTS\"}]},{\"@type\":\"WebSite\",\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#website\",\"url\":\"http:\/\/www.lafabriquedecode.com\/blog\/\",\"name\":\"La Fabrique de code - Tech blog\",\"description\":\"PHP objet, MySQL, Design Patterns, OOP...et plus !\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"http:\/\/www.lafabriquedecode.com\/blog\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"fr-FR\"},{\"@type\":\"Person\",\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"fr-FR\",\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/image\/\",\"url\":\"http:\/\/0.gravatar.com\/avatar\/fc2e1de7c8a1871b50ff9c6a6f8682a2?s=96&d=retro&r=g\",\"contentUrl\":\"http:\/\/0.gravatar.com\/avatar\/fc2e1de7c8a1871b50ff9c6a6f8682a2?s=96&d=retro&r=g\",\"caption\":\"admin\"},\"url\":\"http:\/\/www.lafabriquedecode.com\/blog\/author\/admin\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Le pr\u00e9dicat SQL EXISTS - La Fabrique de code - Tech blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/","og_locale":"fr_FR","og_type":"article","og_title":"Le pr\u00e9dicat SQL EXISTS - La Fabrique de code - Tech blog","og_description":"Le mot cl\u00e9 SQL EXISTS est ce que l&rsquo;on appelle un pr\u00e9dicat, il \u00e9value une (sous-)requ\u00eate et dit si elle contient (true) ou non (false) des tuples. Pour travailler avec, nous allons utiliser deux tables au sch\u00e9ma simplissime, clients et commandes, dont voici les extensions, c&rsquo;est \u00e0 dire l&rsquo;ensemble des tuples qu&rsquo;elles contiennent. Pour trouver [&hellip;]","og_url":"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/","og_site_name":"La Fabrique de code - Tech blog","article_published_time":"2017-12-11T12:25:59+00:00","og_image":[{"url":"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2017\/12\/clients.png"}],"author":"admin","twitter_card":"summary","twitter_creator":"@LaFabrique2Code","twitter_site":"@LaFabrique2Code","twitter_misc":{"\u00c9crit par":"admin","Dur\u00e9e de lecture estim\u00e9e":"3 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/","url":"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/","name":"Le pr\u00e9dicat SQL EXISTS - La Fabrique de code - Tech blog","isPartOf":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/#website"},"datePublished":"2017-12-11T12:25:59+00:00","dateModified":"2017-12-11T12:25:59+00:00","author":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162"},"breadcrumb":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/#breadcrumb"},"inLanguage":"fr-FR","potentialAction":[{"@type":"ReadAction","target":["http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/"]}]},{"@type":"BreadcrumbList","@id":"http:\/\/www.lafabriquedecode.com\/blog\/2017\/12\/le-predicat-sql-exists\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"http:\/\/www.lafabriquedecode.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Le pr\u00e9dicat SQL EXISTS"}]},{"@type":"WebSite","@id":"http:\/\/www.lafabriquedecode.com\/blog\/#website","url":"http:\/\/www.lafabriquedecode.com\/blog\/","name":"La Fabrique de code - Tech blog","description":"PHP objet, MySQL, Design Patterns, OOP...et plus !","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"http:\/\/www.lafabriquedecode.com\/blog\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"fr-FR"},{"@type":"Person","@id":"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162","name":"admin","image":{"@type":"ImageObject","inLanguage":"fr-FR","@id":"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/image\/","url":"http:\/\/0.gravatar.com\/avatar\/fc2e1de7c8a1871b50ff9c6a6f8682a2?s=96&d=retro&r=g","contentUrl":"http:\/\/0.gravatar.com\/avatar\/fc2e1de7c8a1871b50ff9c6a6f8682a2?s=96&d=retro&r=g","caption":"admin"},"url":"http:\/\/www.lafabriquedecode.com\/blog\/author\/admin\/"}]}},"_links":{"self":[{"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts\/1102"}],"collection":[{"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/comments?post=1102"}],"version-history":[{"count":14,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts\/1102\/revisions"}],"predecessor-version":[{"id":1123,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts\/1102\/revisions\/1123"}],"wp:attachment":[{"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/media?parent=1102"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/categories?post=1102"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/tags?post=1102"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}