{"id":70,"date":"2013-04-04T09:06:22","date_gmt":"2013-04-04T07:06:22","guid":{"rendered":"http:\/\/www.lafabriquedecode.com\/blog\/?p=70"},"modified":"2013-04-04T09:43:57","modified_gmt":"2013-04-04T07:43:57","slug":"mysql-loperateur-ensembliste-union","status":"publish","type":"post","link":"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/","title":{"rendered":"MySQL : l&rsquo;op\u00e9rateur ensembliste UNION (1\/2)"},"content":{"rendered":"<p>En alg\u00e8bre relationnelle, UNION est un op\u00e9rateur dit \u00ab\u00a0ensembliste\u00a0\u00bb. Par d\u00e9finition, il travaille sur au moins deux ensembles (l&rsquo;extension de deux relations), qu&rsquo;il agr\u00e8ge tout en\u00a0\u00e9liminant\u00a0les \u00e9ventuels doublons. Cr\u00e9ons deux relations mat\u00e9rialisant des employ\u00e9s et des managers au sein d&rsquo;une entreprise pour voir comment tout cela fonctionne :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">\r\n\r\ncreate table employe (\r\n    id tinyint unsigned NOT NULL PRIMARY KEY,\r\n    nom varchar(20) NOT NULL,\r\n    prenom varchar(30) NOT NULL\r\n);\r\n\r\ncreate table manager(\r\n    id smallint unsigned NOT NULL PRIMARY KEY,\r\n    nom varchar(30),\r\n    prenom varchar(20)\r\n);\r\n\r\nINSERT INTO employe VALUES (1, 'Klein', 'Roger'),\r\n                           (2, 'Bagnole', 'Marcel'),\r\n                           (3, 'De Narvale', 'Nadine');\r\n\r\nINSERT INTO manager VALUES (1, 'Avignon', 'Eric'),\r\n                           (2, 'Avril', 'Mathilda'),\r\n                           (3, 'Klein', 'Roger');\r\n\r\n<\/pre>\n<p>Ces deux relations ont le m\u00eame sch\u00e9ma, c&rsquo;est \u00e0 dire le m\u00eame nombre d&rsquo;attributs; c&rsquo;est une des conditions de l&rsquo;UNION.\u00a0Lorsque l&rsquo;on fait l&rsquo;union de nos deux relations, par la requ\u00eate :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">\r\n\r\nselect * from employe union select * from manager;\r\n\r\n<\/pre>\n<p>On obtient les tuples suivants :<\/p>\n<p><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/snapshot2.png\"><img loading=\"lazy\" class=\"alignnone size-full wp-image-73\" alt=\"snapshot2\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/snapshot2.png\" width=\"156\" height=\"167\" \/><\/a><\/p>\n<p>Vous notez que Roger Klein est pr\u00e9sent deux fois, car il est \u00e0 la fois employ\u00e9 et manager; ce n&rsquo;est pas un doublon au sens strict du terme car il a deux valeurs d&rsquo;identifiant diff\u00e9rentes dans chaque table. Il\u00a0appara\u00eet\u00a0donc logiquement deux fois, ce qui n&rsquo;aurait pas \u00e9t\u00e9 le cas s&rsquo;il avait eu la valeur d&rsquo;id 3 dans <em>employe<\/em> ou de 1 dans <em>manager<\/em>.<\/p>\n<p>La condition pour r\u00e9aliser une UNION, je l&rsquo;ai d\u00e9j\u00e0 dit plus haut, est d&rsquo;avoir le m\u00eame sch\u00e9ma dans les deux tables, c&rsquo;est \u00e0 dire le m\u00eame nombre d&rsquo;attributs; prenons deux tables qui n&rsquo;ont aucun rapport entre elles :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">\r\n\r\ncreate table chevre (\r\n\r\n    id tinyint unsigned NOT NULL PRIMARY KEY,\r\n\r\n    nom varchar(20) NOT NULL,\r\n\r\n    age tinyint unsigned NOT NULL default 0\r\n\r\n);\r\n\r\ncreate table chou (\r\n\r\n    variete varchar(15) NOT NULL PRIMARY KEY,\r\n\r\n    poids tinyint unsigned NOT NULL default 0,\r\n\r\n    couleur varchar(10) NOT NULL\r\n\r\n);\r\n\r\ninsert into chevre values (1, 'Biquette', 10),\r\n                          (2, 'Lola', 13);\r\n\r\ninsert into chou values ('romanesco', 2, 'vert'),\r\n                        ('chinois', 1, 'blanc');\r\n\r\n<\/pre>\n<p>Faisons l&rsquo;UNION de ces deux relations de m\u00eame sch\u00e9ma :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">\r\n\r\nselect * from chevre UNION select * from chou;\r\n\r\n<\/pre>\n<p>Je ne comprends pas, on me r\u00e9p\u00e8te depuis tout petit qu&rsquo;il ne faut pas m\u00e9nager la ch\u00e8vre et le chou et pourtant, stupeur&#8230;<\/p>\n<p><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/snapshot21.png\"><img loading=\"lazy\" class=\"alignnone size-full wp-image-77\" alt=\"snapshot2\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/snapshot21.png\" width=\"180\" height=\"125\" \/><\/a><\/p>\n<p>C&rsquo;est tout \u00e0 fait possible d&rsquo;avoir les deux ! Vous avez vu que mes champs sont m\u00e9lang\u00e9s, il ne sont pas de m\u00eame type (le premier champ de <em>chevre<\/em> est un entier non sign\u00e9 alors que le premier champ de <em>chou<\/em> est une cha\u00eene de caract\u00e8res, le deuxi\u00e8me est une cha\u00eene de caract\u00e8res dans l&rsquo;un et un entier dans l&rsquo;autre, etc.). Au final, le r\u00e9sultat de notre union ne veut pas dire grand chose s\u00e9mantiquement parlant, regardez le nom des colonnes : nom contient le nom de nos sympathiques caprins mais aussi le poids de nos choux, age contient l&rsquo;\u00e2ge de nos ruminants mais aussi la couleur de nos choux.<\/p>\n<p>Maman avait donc raison : on ne doit pas m\u00e9nager la ch\u00e8vre et le chou !<\/p>\n","protected":false},"excerpt":{"rendered":"<p>En alg\u00e8bre relationnelle, UNION est un op\u00e9rateur dit \u00ab\u00a0ensembliste\u00a0\u00bb. Par d\u00e9finition, il travaille sur au moins deux ensembles (l&rsquo;extension de deux relations), qu&rsquo;il agr\u00e8ge tout en\u00a0\u00e9liminant\u00a0les \u00e9ventuels doublons. Cr\u00e9ons deux relations mat\u00e9rialisant des employ\u00e9s et des managers au sein d&rsquo;une entreprise pour voir comment tout cela fonctionne : Ces deux relations ont le m\u00eame sch\u00e9ma, [&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":[2],"tags":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v19.6.1 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>MySQL : l&#039;op\u00e9rateur ensembliste UNION (1\/2) - 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=\"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/\" \/>\n<meta property=\"og:locale\" content=\"fr_FR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"MySQL : l&#039;op\u00e9rateur ensembliste UNION (1\/2) - La Fabrique de code - Tech blog\" \/>\n<meta property=\"og:description\" content=\"En alg\u00e8bre relationnelle, UNION est un op\u00e9rateur dit \u00ab\u00a0ensembliste\u00a0\u00bb. Par d\u00e9finition, il travaille sur au moins deux ensembles (l&rsquo;extension de deux relations), qu&rsquo;il agr\u00e8ge tout en\u00a0\u00e9liminant\u00a0les \u00e9ventuels doublons. Cr\u00e9ons deux relations mat\u00e9rialisant des employ\u00e9s et des managers au sein d&rsquo;une entreprise pour voir comment tout cela fonctionne : Ces deux relations ont le m\u00eame sch\u00e9ma, [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/\" \/>\n<meta property=\"og:site_name\" content=\"La Fabrique de code - Tech blog\" \/>\n<meta property=\"article:published_time\" content=\"2013-04-04T07:06:22+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2013-04-04T07:43:57+00:00\" \/>\n<meta property=\"og:image\" content=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/snapshot2.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\":\"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/\",\"url\":\"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/\",\"name\":\"MySQL : l'op\u00e9rateur ensembliste UNION (1\/2) - La Fabrique de code - Tech blog\",\"isPartOf\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#website\"},\"datePublished\":\"2013-04-04T07:06:22+00:00\",\"dateModified\":\"2013-04-04T07:43:57+00:00\",\"author\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/#breadcrumb\"},\"inLanguage\":\"fr-FR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"http:\/\/www.lafabriquedecode.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"MySQL : l&rsquo;op\u00e9rateur ensembliste UNION (1\/2)\"}]},{\"@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":"MySQL : l'op\u00e9rateur ensembliste UNION (1\/2) - 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":"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/","og_locale":"fr_FR","og_type":"article","og_title":"MySQL : l'op\u00e9rateur ensembliste UNION (1\/2) - La Fabrique de code - Tech blog","og_description":"En alg\u00e8bre relationnelle, UNION est un op\u00e9rateur dit \u00ab\u00a0ensembliste\u00a0\u00bb. Par d\u00e9finition, il travaille sur au moins deux ensembles (l&rsquo;extension de deux relations), qu&rsquo;il agr\u00e8ge tout en\u00a0\u00e9liminant\u00a0les \u00e9ventuels doublons. Cr\u00e9ons deux relations mat\u00e9rialisant des employ\u00e9s et des managers au sein d&rsquo;une entreprise pour voir comment tout cela fonctionne : Ces deux relations ont le m\u00eame sch\u00e9ma, [&hellip;]","og_url":"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/","og_site_name":"La Fabrique de code - Tech blog","article_published_time":"2013-04-04T07:06:22+00:00","article_modified_time":"2013-04-04T07:43:57+00:00","og_image":[{"url":"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/snapshot2.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":"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/","url":"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/","name":"MySQL : l'op\u00e9rateur ensembliste UNION (1\/2) - La Fabrique de code - Tech blog","isPartOf":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/#website"},"datePublished":"2013-04-04T07:06:22+00:00","dateModified":"2013-04-04T07:43:57+00:00","author":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162"},"breadcrumb":{"@id":"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/#breadcrumb"},"inLanguage":"fr-FR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-loperateur-ensembliste-union\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"http:\/\/www.lafabriquedecode.com\/blog\/"},{"@type":"ListItem","position":2,"name":"MySQL : l&rsquo;op\u00e9rateur ensembliste UNION (1\/2)"}]},{"@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\/70"}],"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=70"}],"version-history":[{"count":10,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts\/70\/revisions"}],"predecessor-version":[{"id":72,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts\/70\/revisions\/72"}],"wp:attachment":[{"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/media?parent=70"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/categories?post=70"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/tags?post=70"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}