{"id":221,"date":"2013-04-15T10:56:05","date_gmt":"2013-04-15T08:56:05","guid":{"rendered":"http:\/\/www.lafabriquedecode.com\/blog\/?p=221"},"modified":"2013-04-15T10:56:05","modified_gmt":"2013-04-15T08:56:05","slug":"mysql-difference-entre-et-like-dans-un-select","status":"publish","type":"post","link":"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/","title":{"rendered":"MySQL : diff\u00e9rence entre = et LIKE dans un SELECT"},"content":{"rendered":"<div id=\"attachment_260\" style=\"width: 210px\" class=\"wp-caption alignnone\"><a href=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/like_a_boss.jpg\"><img aria-describedby=\"caption-attachment-260\" loading=\"lazy\" class=\"size-full wp-image-260\" alt=\"like a boss !\" src=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/like_a_boss.jpg\" width=\"200\" height=\"200\" srcset=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/like_a_boss.jpg 200w, http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/like_a_boss-150x150.jpg 150w\" sizes=\"(max-width: 200px) 100vw, 200px\" \/><\/a><p id=\"caption-attachment-260\" class=\"wp-caption-text\">LIKE&#8230;a bo$$ !<\/p><\/div>\n<p>On entend souvent dire qu&rsquo;utiliser l&rsquo;op\u00e9rateur arithm\u00e9tique = ou faire un LIKE sur une cha\u00eene de caract\u00e8res dans MySQL revient au m\u00eame. Oui et non&#8230;Oui car au final les tuples qui \u00ab\u00a0remontent\u00a0\u00bb de nos tables sont les m\u00eames mais non car en coulisses l&rsquo;impact sur le temps d&rsquo;ex\u00e9cution n&rsquo;est pas forc\u00e9ment le m\u00eame.<br \/>\nVoyons sans plus tarder un exemple avec une table compos\u00e9e de 2 champs; un champ char(6) qui occupe donc 6 octets puisque les cha\u00eenes g\u00e9n\u00e9r\u00e9es le sont avec des caract\u00e8res ASCII et un champ varchar(6) qui va occuper 7 octets &#8211; un pr\u00e9fixe d&rsquo;un octet + nos 6 octets de caract\u00e8res &#8211; dans laquelle nous ins\u00e9rons des cha\u00eenes de caract\u00e8res al\u00e9atoires et en nombre assez cons\u00e9quent (100 000 entr\u00e9es). Ne vous inqui\u00e9tez pas si cela prend quelques secondes \u00e0 s&rsquo;ex\u00e9cuter&#8230;<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">\r\nCREATE TABLE test_like (\r\n    cha char(6) NOT NULL,\r\n    var varchar(6) NOT NULL\r\n) ENGINE=InnoDB DEFAULT CHARSET=utf8;\r\n\r\n-- le d\u00e9but de notre proc' stock'\r\n\r\nDROP PROCEDURE IF EXISTS insertion;\r\n\r\nDELIMITER \/\/\r\nCREATE PROCEDURE insertion()\r\nBEGIN\r\n    DECLARE i INT DEFAULT 1;\r\n\r\n    WHILE (i&lt;=100000) DO\r\n        INSERT INTO test_like VALUES\r\n        (\r\n        SUBSTRING(MD5(RAND()) FROM 1 FOR 6),\r\n        SUBSTRING(MD5(RAND()) FROM 1 FOR 6));\r\n        SET i=i+1;\r\n    END WHILE;\r\nEND\r\n\/\/\r\nCALL insertion();\r\n\r\n<\/pre>\n<p>C&rsquo;est vrai que de prime abord faire<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\"> select * from test_like\r\nwhere cha like 'ee43b9' <\/pre>\n<p>ou<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\"> select * from test_like\r\nwhere cha = 'ee43b9' <\/pre>\n<p>sur notre champ de type CHAR revient au m\u00eame, tout comme :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">select * from test_like\r\nwhere var like 'fb7bb8'<\/pre>\n<p>produit le m\u00eame r\u00e9sultat que<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">select * from test_like\r\nwhere var = 'fb7bb8'<\/pre>\n<p>J&rsquo;ai lu sur certains forums anglophones que le comportement de = ou like d\u00e9pendait du type de donn\u00e9es de la colonne (CHAR\/VARCHAR), c&rsquo;est peut-\u00eatre vrai sur certains RDBMS, mais pas avec MySQL, vous en avez la preuve concr\u00e8te. Le changement est surtout visible lorsque l&rsquo;on pose un index sur la colonne concern\u00e9e :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">ALTER TABLE test_like ADD INDEX (cha)<\/pre>\n<p>Ainsi, voici ce que nous donne un EXPLAIN. Tout d&rsquo;abord sur le LIKE :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">explain select * from test_like where cha like 'ee43b9'<\/pre>\n<p>+&#8212;-+&#8212;&#8212;&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8211;+&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;-+<br \/>\n| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |<br \/>\n+&#8212;-+&#8212;&#8212;&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8211;+&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;-+<br \/>\n| 1 | SIMPLE | test_like | range | cha | cha | 18 | NULL | 1 | Using where |<br \/>\n+&#8212;-+&#8212;&#8212;&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8211;+&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;-+<br \/>\n1 row in set (0.01 sec)<\/p>\n<p>Et ensuite sur le = :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">explain select * from test_like where cha = 'ee43b9'<\/pre>\n<p>+&#8212;-+&#8212;&#8212;&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8211;+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;+&#8212;&#8212;-+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;-+<br \/>\n| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |<br \/>\n+&#8212;-+&#8212;&#8212;&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8211;+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;+&#8212;&#8212;-+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;-+<br \/>\n| 1 | SIMPLE | test_like | ref | cha | cha | 18 | const | 1 | Using where |<br \/>\n+&#8212;-+&#8212;&#8212;&#8212;&#8212;-+&#8212;&#8212;&#8212;&#8211;+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;&#8212;+&#8212;&#8212;+&#8212;&#8212;&#8212;+&#8212;&#8212;-+&#8212;&#8212;+&#8212;&#8212;&#8212;&#8212;-+<br \/>\n1 row in set (0.01 sec)<\/p>\n<p>Nous obtenons la m\u00eame chose sur le champ de type VARCHAR apr\u00e8s avoir pos\u00e9 un index dessus. Une recherche avec un LIKE sur un champ index\u00e9 donne un <strong>type = range<\/strong> alors qu&rsquo;une recherche sur un champ index\u00e9 donne avec une \u00e9galit\u00e9 stricte un <strong>type = ref<\/strong>. Voyons ce que dit la documentation officielle \u00e0 ce sujet :<\/p>\n<blockquote><p><code>ref<\/code>\u00a0peut \u00eatre utilis\u00e9 pour les colonnes index\u00e9es, qui sont compar\u00e9es avec l&rsquo;op\u00e9rateur\u00a0<code>=<\/code>.<\/p><\/blockquote>\n<p>C&rsquo;est bien le cas ! Pour le range :<\/p>\n<blockquote><p><code>range<\/code>\u00a0peut \u00eatre utilis\u00e9 lorsqu&rsquo;une colonne index\u00e9e est compar\u00e9e avec une constante comme\u00a0<code>=<\/code>,\u00a0<code>&lt;&gt;<\/code>,\u00a0<code>&gt;<\/code>,\u00a0<code>&gt;=<\/code>,\u00a0<code>&lt;<\/code>,\u00a0<code>&lt;=<\/code>,<code>IS NULL<\/code>,\u00a0<code>&lt;=&gt;<\/code>,\u00a0<code>BETWEEN<\/code>\u00a0ou\u00a0<code>IN<\/code>.<\/p><\/blockquote>\n<p><span style=\"font-size: 1rem; line-height: 1.714285714;\">Les exemples de la\u00a0<\/span>documentation<span style=\"font-size: 1rem; line-height: 1.714285714;\">\u00a0officielle montrent bien que range peut-\u00eatre AUSSI utilis\u00e9 avec un = mais plut\u00f4t sur des types de donn\u00e9es num\u00e9riques&#8230;<\/span><\/p>\n<p><strong>Les tests r\u00e9alis\u00e9s sur un serveur MySQL situ\u00e9 sur le r\u00e9seau local<\/strong><\/p>\n<p><strong>Pour le champ de type CHAR<\/strong><\/p>\n<p>CHAR(6) index\u00e9, LIKE sur une valeur existante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT\u00a0SQL_NO_CACHE\u00a0*\r\n     FROM\u00a0test_like\r\n     WHERE\u00a0cha\u00a0LIKE\u00a0'edd34e'\r\n<\/pre>\n<pre>\r\n1 total, Traitement en 0.0103 sec.\r\n<\/pre>\n<p>CHAR(6) index\u00e9, LIKE sur une valeur inexistante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT\u00a0SQL_NO_CACHE\u00a0*\r\n     FROM\u00a0test_like\r\n     WHERE\u00a0cha\u00a0LIKE\u00a0'fb7bb8'<\/pre>\n<pre>\r\nMySQL n'a retourn\u00e9 aucune ligne. ( Traitement en 0.0007 sec. )\r\n<\/pre>\n<p>CHAR(6) index\u00e9, = sur une valeur existante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT SQL_NO_CACHE *\r\n     FROM test_like\r\n     WHERE cha =  'edd34e'<\/pre>\n<pre>\r\nTraitement en 0.0008 sec.\r\n<\/pre>\n<p>CHAR(6) index\u00e9, = sur une valeur inexistante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT SQL_NO_CACHE *\r\n     FROM test_like\r\n     WHERE cha =  'udd34e'<\/pre>\n<pre>\r\nMySQL n'a retourn\u00e9 aucune ligne. ( Traitement en 0.0006 sec. )\r\n<\/pre>\n<p><strong>Pour le champ de type VARCHAR<\/strong><\/p>\n<p>VARCHAR(6) index\u00e9, LIKE sur une valeur existante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT SQL_NO_CACHE *\r\n     FROM test_like\r\n     WHERE var LIKE  '64eaee'<\/pre>\n<pre>\r\n1 total, Traitement en 0.0455 sec.\r\n<\/pre>\n<p>VARCHAR(6) index\u00e9, LIKE sur une valeur inexistante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT SQL_NO_CACHE *\r\n     FROM test_like\r\n     WHERE var LIKE  '88eaee'<\/pre>\n<pre>\r\nMySQL n'a retourn\u00e9 aucune ligne. ( Traitement en 0.0659 sec. )\r\n<\/pre>\n<p>VARCHAR(6) index\u00e9, = sur une valeur existante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT SQL_NO_CACHE *\r\n     FROM test_like\r\n     WHERE var =  '6753ec'<\/pre>\n<pre>\r\n1 total, Traitement en 0.0520 sec.\r\n<\/pre>\n<p>VARCHAR(6) index\u00e9, = sur une valeur inexistante, bypass du cache de requ\u00eates MySQL :<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">SELECT SQL_NO_CACHE *\r\n     FROM test_like\r\n     WHERE var =  '8888ec'<\/pre>\n<pre>\r\nMySQL n'a retourn\u00e9 aucune ligne. ( Traitement en 0.0513 sec. )\r\n<\/pre>\n<p>D&rsquo;apr\u00e8s ce petit benchmark tr\u00e8s rapide et sans grande pr\u00e9tention :<\/p>\n<ul>\n<li>sur un VARCHAR, like est un peu plus rapide que =<\/li>\n<li>sur un CHAR <strong>int\u00e9gralement rempli<\/strong>, = est beaucoup plus rapide que like<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>On entend souvent dire qu&rsquo;utiliser l&rsquo;op\u00e9rateur arithm\u00e9tique = ou faire un LIKE sur une cha\u00eene de caract\u00e8res dans MySQL revient au m\u00eame. Oui et non&#8230;Oui car au final les tuples qui \u00ab\u00a0remontent\u00a0\u00bb de nos tables sont les m\u00eames mais non car en coulisses l&rsquo;impact sur le temps d&rsquo;ex\u00e9cution n&rsquo;est pas forc\u00e9ment le m\u00eame. Voyons sans [&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 : diff\u00e9rence entre = et LIKE dans un SELECT - 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\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/\" \/>\n<meta property=\"og:locale\" content=\"fr_FR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"MySQL : diff\u00e9rence entre = et LIKE dans un SELECT - La Fabrique de code - Tech blog\" \/>\n<meta property=\"og:description\" content=\"On entend souvent dire qu&rsquo;utiliser l&rsquo;op\u00e9rateur arithm\u00e9tique = ou faire un LIKE sur une cha\u00eene de caract\u00e8res dans MySQL revient au m\u00eame. Oui et non&#8230;Oui car au final les tuples qui \u00ab\u00a0remontent\u00a0\u00bb de nos tables sont les m\u00eames mais non car en coulisses l&rsquo;impact sur le temps d&rsquo;ex\u00e9cution n&rsquo;est pas forc\u00e9ment le m\u00eame. Voyons sans [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/\" \/>\n<meta property=\"og:site_name\" content=\"La Fabrique de code - Tech blog\" \/>\n<meta property=\"article:published_time\" content=\"2013-04-15T08:56:05+00:00\" \/>\n<meta property=\"og:image\" content=\"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/like_a_boss.jpg\" \/>\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=\"5 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/\",\"url\":\"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/\",\"name\":\"MySQL : diff\u00e9rence entre = et LIKE dans un SELECT - La Fabrique de code - Tech blog\",\"isPartOf\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#website\"},\"datePublished\":\"2013-04-15T08:56:05+00:00\",\"dateModified\":\"2013-04-15T08:56:05+00:00\",\"author\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162\"},\"breadcrumb\":{\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/#breadcrumb\"},\"inLanguage\":\"fr-FR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"http:\/\/www.lafabriquedecode.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"MySQL : diff\u00e9rence entre = et LIKE dans un SELECT\"}]},{\"@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 : diff\u00e9rence entre = et LIKE dans un SELECT - 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\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/","og_locale":"fr_FR","og_type":"article","og_title":"MySQL : diff\u00e9rence entre = et LIKE dans un SELECT - La Fabrique de code - Tech blog","og_description":"On entend souvent dire qu&rsquo;utiliser l&rsquo;op\u00e9rateur arithm\u00e9tique = ou faire un LIKE sur une cha\u00eene de caract\u00e8res dans MySQL revient au m\u00eame. Oui et non&#8230;Oui car au final les tuples qui \u00ab\u00a0remontent\u00a0\u00bb de nos tables sont les m\u00eames mais non car en coulisses l&rsquo;impact sur le temps d&rsquo;ex\u00e9cution n&rsquo;est pas forc\u00e9ment le m\u00eame. Voyons sans [&hellip;]","og_url":"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/","og_site_name":"La Fabrique de code - Tech blog","article_published_time":"2013-04-15T08:56:05+00:00","og_image":[{"url":"http:\/\/www.lafabriquedecode.com\/blog\/wp-content\/uploads\/2013\/04\/like_a_boss.jpg"}],"author":"admin","twitter_card":"summary","twitter_creator":"@LaFabrique2Code","twitter_site":"@LaFabrique2Code","twitter_misc":{"\u00c9crit par":"admin","Dur\u00e9e de lecture estim\u00e9e":"5 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/","url":"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/","name":"MySQL : diff\u00e9rence entre = et LIKE dans un SELECT - La Fabrique de code - Tech blog","isPartOf":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/#website"},"datePublished":"2013-04-15T08:56:05+00:00","dateModified":"2013-04-15T08:56:05+00:00","author":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/#\/schema\/person\/83863c048b82fd9ccf6407bddd241162"},"breadcrumb":{"@id":"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/#breadcrumb"},"inLanguage":"fr-FR","potentialAction":[{"@type":"ReadAction","target":["http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/"]}]},{"@type":"BreadcrumbList","@id":"http:\/\/www.lafabriquedecode.com\/blog\/2013\/04\/mysql-difference-entre-et-like-dans-un-select\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"http:\/\/www.lafabriquedecode.com\/blog\/"},{"@type":"ListItem","position":2,"name":"MySQL : diff\u00e9rence entre = et LIKE dans un SELECT"}]},{"@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\/221"}],"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=221"}],"version-history":[{"count":43,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts\/221\/revisions"}],"predecessor-version":[{"id":265,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/posts\/221\/revisions\/265"}],"wp:attachment":[{"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/media?parent=221"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/categories?post=221"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.lafabriquedecode.com\/blog\/wp-json\/wp\/v2\/tags?post=221"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}