{"id":717,"date":"2020-11-23T14:13:08","date_gmt":"2020-11-23T06:13:08","guid":{"rendered":"https:\/\/www.cxybj.com\/?p=717"},"modified":"2020-11-23T14:22:22","modified_gmt":"2020-11-23T06:22:22","slug":"laravel%e7%9a%84tosql%e6%96%b9%e6%b3%95dd%e6%89%93%e5%8d%b0%e7%b4%a0%e7%bb%84%e6%88%96%e5%8f%98%e9%87%8f%e5%8f%82%e6%95%b0%e7%bb%93%e6%9e%9c%e6%98%af%e9%97%ae%e5%8f%b7","status":"publish","type":"post","link":"https:\/\/www.cxybj.com\/?p=717","title":{"rendered":"Laravel\u7684toSql()\u65b9\u6cd5dd()\u6253\u5370\u6570\u7ec4\u6216\u53d8\u91cf\u53c2\u6570\u7ed3\u679c\u662f\u95ee\u53f7?"},"content":{"rendered":"<p>\u9ed8\u8ba4toSql \u83b7\u53d6\u5230\u7684 sql \u91cc\u9762\u7684\u53c2\u6570\u4f7f\u7528 &#8220;?&#8221; \u4ee3\u66ff\u7684\uff0c\u5982\u4e0b\uff1a<br \/>\nDB::table(&#8216;news&#8217;)-&gt;where(&#8216;id&#8217;, 1)-&gt;toSql();<br \/>\n\u83b7\u53d6\u5230\u7684 sql \u8bed\u53e5\u662f\uff1a<br \/>\nselect * from `cxybj_news` where `id` = ?<br \/>\n\u6709\u65f6\u5019\u6211\u4eec\u60f3\u8981\u5f97\u5230\u5177\u4f53\u7684\u8bed\u53e5\uff0c\u53ef\u4ee5\u5229\u7528 builder \u7684 getBindings \u65b9\u6cd5\uff1a<br \/>\n$builder = DB::table(&#8216;news&#8217;)-&gt;where(&#8216;id&#8217;, 1);<br \/>\n$bindings = $builder-&gt;getBindings();<br \/>\n$sql = str_replace(&#8216;?&#8217;, &#8216;%s&#8217;, $builder-&gt;toSql());<br \/>\n$sql = sprintf($sql, &#8230;$bindings);<br \/>\ndd($sql);<br \/>\n\u83b7\u53d6\u5230\u7684 sql \u8bed\u53e5\u662f\uff1a<br \/>\nselect * from `cxybj_news` where `id` = 1<br \/>\n\u5982\u679c\u7ecf\u5e38\u4f7f\u7528\u53ef\u4ee5\u8003\u8651\u4f7f\u7528 Builder \u7684 macro \u65b9\u6cd5\u52a0\u8fdb Builder \u91cc\u9762\uff1a\\Illuminate\\Database\\Query\\Builder::macro(&#8216;sql&#8217;, function () {<br \/>\n$bindings = $this-&gt;getBindings();<br \/>\n$sql = str_replace(&#8216;?&#8217;, &#8216;%s&#8217;, $this-&gt;toSql());<br \/>\nreturn sprintf($sql, &#8230;$bindings);<br \/>\n});<br \/>\ndd(DB::table(&#8216;news&#8217;)-&gt;where(&#8216;id&#8217;, 1)-&gt;sql());<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u9ed8\u8ba4toSql \u83b7\u53d6\u5230\u7684 sql \u91cc\u9762\u7684\u53c2\u6570\u4f7f\u7528 &#038;#822 &hellip; <a href=\"https:\/\/www.cxybj.com\/?p=717\" class=\"more-link\">Read More<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[135,2],"tags":[],"_links":{"self":[{"href":"https:\/\/www.cxybj.com\/index.php?rest_route=\/wp\/v2\/posts\/717"}],"collection":[{"href":"https:\/\/www.cxybj.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.cxybj.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.cxybj.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.cxybj.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=717"}],"version-history":[{"count":3,"href":"https:\/\/www.cxybj.com\/index.php?rest_route=\/wp\/v2\/posts\/717\/revisions"}],"predecessor-version":[{"id":723,"href":"https:\/\/www.cxybj.com\/index.php?rest_route=\/wp\/v2\/posts\/717\/revisions\/723"}],"wp:attachment":[{"href":"https:\/\/www.cxybj.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=717"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.cxybj.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=717"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.cxybj.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=717"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}