{"id":230443,"date":"2022-11-29T12:33:00","date_gmt":"2022-11-29T09:33:00","guid":{"rendered":"https:\/\/wordpress.mediadoma.com\/?p=230443"},"modified":"2022-11-09T22:25:00","modified_gmt":"2022-11-09T19:25:00","slug":"utilisation-de-sprintf-et-like-dans-les-requetes-sql-dans-wordpress","status":"publish","type":"post","link":"https:\/\/wordpress.mediadoma.com\/fr\/utilisation-de-sprintf-et-like-dans-les-requetes-sql-dans-wordpress\/","title":{"rendered":"Utilisation de sprintf et LIKE dans les requ\u00eates SQL dans WordPress"},"content":{"rendered":"<p>Lorsque vous travaillez avec des requ\u00eates dans WordPress, il est toujours pr\u00e9f\u00e9rable de <a href=\"https:\/\/developer.wordpress.org\/reference\/classes\/wpdb\/prepare\/\" target=\"_blank\" rel=\"noopener nofollow\" class=\"external external_icon\">pr\u00e9parer<\/a> la requ\u00eate avant de l&rsquo;ex\u00e9cuter ; Cependant, s&rsquo;il vous arrive d&rsquo;interagir avec une API tierce ou de travailler avec une autre variante de SQL (comme Transact-SQL), les choses peuvent fonctionner un peu diff\u00e9remment.<\/p>\n<p>Si seulement les bases de donn\u00e9es \u00e9taient vraiment aussi soign\u00e9es.<\/p>\n<p>Le <strong>TL; DR<\/strong> de tout cela est que la gestion de <a href=\"https:\/\/php.net\/manual\/en\/function.sprintf.php\" target=\"_blank\" rel=\"noopener nofollow\" class=\"external external_icon\">sprintf<\/a> et <strong><a href=\"https:\/\/docs.microsoft.com\/en-us\/sql\/t-sql\/language-elements\/like-transact-sql?view=sql-server-2017\" target=\"_blank\" rel=\"noopener nofollow\" class=\"external external_icon\">LIKE dans T-SQL<\/a><\/strong> n\u00e9cessite une gestion strat\u00e9gique. Et l&rsquo;exemple de code dans la section suivante devrait fournir tout ce dont vous avez besoin.<\/p>\n<h2>sprintf et LIKE en SQL<\/h2>\n<p>Quelques informations sur le probl\u00e8me en cours\u00a0:<\/p>\n<p>Supposons que vous travaillez sur un projet dans lequel vous effectuez des appels \u00e0 une API tierce et que ladite API utilise T-SQL pour s&rsquo;interfacer avec sa base de donn\u00e9es.<\/p>\n<p>De plus, supposons que vous souhaitiez r\u00e9cup\u00e9rer des enregistrements contenant un segment de la cha\u00eene \u00e0 interroger (vous savez, une clause <strong>LIKE ).<\/strong> La mise en garde est que vous ne pouvez pas utiliser la fonction de <strong>pr\u00e9paration<\/strong> standard fournie par WordPress, vous choisissez donc d&rsquo;utiliser <strong>sprintf<\/strong> pour aider \u00e0 nettoyer les informations entrantes.<\/p>\n<p>\u00c9tant donn\u00e9 que <strong>sprintf<\/strong> utilise <code>%s<\/code>des cha\u00eenes et que vous utilisez une clause <strong>LIKE<\/strong> qui n\u00e9cessite \u00e9galement <code>%<\/code>, comment g\u00e9rer le cas d&rsquo;utilisation des deux\u00a0?<\/p>\n<p><strong><a href=\"https:\/\/gist.github.com\/tommcfarlin\/b4d5a391024b151667fe99f5bd913544#file-00-get-user-by-last-name-php\" target=\"_blank\" rel=\"noopener nofollow\" class=\"external external_icon\">Voici un exemple<\/a><\/strong> de la fa\u00e7on dont cela peut fonctionner pour vous\u00a0:<\/p>\n<pre><code>&lt;?php\n\/**\n * Queries a third-party API using sprintf and a LIKE clause to retrieve the users \n * with a last name like the specified argument.\n * \n * @param string $lastName An unsanitized version of the user's last name.\n *\/\npublic function getUserByLastName(string $lastName)\n{\n    \/\/ Sanitize the argument as you see fit here.\n\n    $query = sprintf(\"\n        SELECT FIRST_NAME, LAST_NAME\n        FROM USERINFO\n        WHERE LAST_NAME LIKE '%%%s%%'\n    \", $lastName);\n\n    \/\/ Make a query to the third-party API here.\n}\n<\/code><\/pre>\n<p>Bien s\u00fbr, je pense toujours utiliser un certain type d&rsquo;\u00e9vasion sur l&rsquo; <code>$name<\/code>argument, mais il existe un certain nombre de fa\u00e7ons diff\u00e9rentes de le faire et c&rsquo;est au-del\u00e0 du but de ce post.<\/p>\n<p>En bref, pr\u00e9fixez et suffixez le <code>%s<\/code>avec <code>%%<\/code>et vous devriez \u00eatre pr\u00eat \u00e0 partir.<\/p>\n<p><div id=\"PostUnique_PostSource\" style=\"padding-top: 50px\">Source d&rsquo;enregistrement:  <a target=\"_blank\" rel=\"noopener nofollow\" href=\"\/\/tommcfarlin.com\" class=\"external external_icon\">tommcfarlin.com<\/a><\/div><\/p>\n","protected":false},"excerpt":{"rendered":"<p>La gestion de sprintf et LIKE dans T-SQL n\u00e9cessite une gestion strat\u00e9gique et voici comment proc\u00e9der.<\/p>\n","protected":false},"author":1,"featured_media":163659,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":"","_wp_rev_ctl_limit":""},"categories":[717,841,862],"tags":[1167],"class_list":["post-230443","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-developpeur","category-tutoriels","category-wordpress-3","tag-affiai-fr"],"_links":{"self":[{"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/posts\/230443","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/comments?post=230443"}],"version-history":[{"count":0,"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/posts\/230443\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/media\/163659"}],"wp:attachment":[{"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/media?parent=230443"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/categories?post=230443"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/fr\/wp-json\/wp\/v2\/tags?post=230443"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}