{"id":230567,"date":"2022-11-29T12:47:00","date_gmt":"2022-11-29T09:47:00","guid":{"rendered":"https:\/\/wordpress.mediadoma.com\/?p=230567"},"modified":"2022-11-09T23:00:11","modified_gmt":"2022-11-09T20:00:11","slug":"usando-sprintf-e-like-em-consultas-sql-no-wordpress","status":"publish","type":"post","link":"https:\/\/wordpress.mediadoma.com\/pt-pt\/usando-sprintf-e-like-em-consultas-sql-no-wordpress\/","title":{"rendered":"Usando sprintf e LIKE em consultas SQL no WordPress"},"content":{"rendered":"<p>Ao trabalhar com consultas no WordPress, \u00e9 sempre melhor <a href=\"https:\/\/developer.wordpress.org\/reference\/classes\/wpdb\/prepare\/\" target=\"_blank\" rel=\"noopener nofollow\" class=\"external external_icon\">preparar<\/a> a consulta antes de execut\u00e1-la; no entanto, se voc\u00ea estiver fazendo interface com uma API de terceiros ou trabalhando com outra variante do SQL (como Transact-SQL), as coisas podem funcionar de maneira um pouco diferente.<\/p>\n<p>Se apenas os bancos de dados fossem realmente t\u00e3o legais.<\/p>\n<p>O <strong>TL;DR<\/strong> de tudo isso \u00e9 que lidar com <a href=\"https:\/\/php.net\/manual\/en\/function.sprintf.php\" target=\"_blank\" rel=\"noopener nofollow\" class=\"external external_icon\">sprintf<\/a> e <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 em T-SQL<\/a><\/strong> precisa de algum tratamento estrat\u00e9gico. E o exemplo de c\u00f3digo na pr\u00f3xima se\u00e7\u00e3o deve fornecer tudo o que voc\u00ea precisa.<\/p>\n<h2>sprintf e LIKE no SQL<\/h2>\n<p>Alguns antecedentes sobre o problema em quest\u00e3o:<\/p>\n<p>Digamos que voc\u00ea esteja trabalhando em um projeto no qual est\u00e1 fazendo chamadas para uma API de terceiros e a referida API usa T-SQL para fazer interface com seu banco de dados.<\/p>\n<p>Al\u00e9m disso, digamos que voc\u00ea queira recuperar registros que tenham um segmento da string a ser consultada (voc\u00ea sabe, uma cl\u00e1usula <strong>LIKE ).<\/strong> A ressalva \u00e9 que voc\u00ea n\u00e3o pode usar a fun\u00e7\u00e3o de <strong>prepara\u00e7\u00e3o<\/strong> padr\u00e3o fornecida pelo WordPress, ent\u00e3o opte por usar <strong>sprintf<\/strong> para ajudar a limpar as informa\u00e7\u00f5es recebidas.<\/p>\n<p>Como o <strong>sprintf<\/strong> usa <code>%s<\/code>strings e voc\u00ea est\u00e1 usando uma cl\u00e1usula <strong>LIKE<\/strong><code>%<\/code> que tamb\u00e9m requer, como lidar com o caso de usar ambos?<\/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\">Aqui est\u00e1 um exemplo<\/a><\/strong> de como isso pode funcionar para voc\u00ea:<\/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>Claro, eu ainda acho que usar algum tipo de escape no <code>$name<\/code>argumento, mas existem v\u00e1rias maneiras diferentes de fazer isso e est\u00e1 al\u00e9m do objetivo deste post.<\/p>\n<p>Em suma, prefixe e sufixo o <code>%s<\/code>com <code>%%<\/code>e voc\u00ea deve estar pronto para ir.<\/p>\n<p><div id=\"PostUnique_PostSource\" style=\"padding-top: 50px\">Fonte de grava\u00e7\u00e3o:  <a target=\"_blank\" rel=\"noopener nofollow\" href=\"\/\/tommcfarlin.com\" class=\"external external_icon\">tommcfarlin.com<\/a><\/div><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Manipular sprintf e LIKE em T-SQL precisa de algum tratamento estrat\u00e9gico e \u00e9 assim que se faz.<\/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":[722,846,867],"tags":[1170],"class_list":["post-230567","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-desenvolvedor","category-tutoriais","category-wordpress-8","tag-affiai-pt-pt"],"_links":{"self":[{"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/posts\/230567","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/comments?post=230567"}],"version-history":[{"count":0,"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/posts\/230567\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/media\/163659"}],"wp:attachment":[{"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/media?parent=230567"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/categories?post=230567"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/wordpress.mediadoma.com\/pt-pt\/wp-json\/wp\/v2\/tags?post=230567"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}