{"id":2858,"date":"2011-03-10T22:37:04","date_gmt":"2011-03-10T14:37:04","guid":{"rendered":"http:\/\/www.orczhou.com\/?p=2858"},"modified":"2011-03-10T22:41:57","modified_gmt":"2011-03-10T14:41:57","slug":"php-sql-format","status":"publish","type":"post","link":"https:\/\/www.orczhou.com\/index.php\/2011\/03\/php-sql-format\/","title":{"rendered":"\u683c\u5f0f\u5316\u8f93\u51faSQL"},"content":{"rendered":"<p>\u5de5\u4f5c\u4e2d\uff0c\u7ecf\u5e38\u9700\u8981\u5728web\u9875\u9762\u4e2d\u628aSQL\uff08MySQL\uff09\u5c55\u793a\u7ed9\u5f00\u53d1\u4eba\u5458\uff0c\u5982\u679cSQL\u4e0d\u683c\u5f0f\u8bdd\uff0c\u4f8b\u5982\uff1a<\/p>\n<p><a href=\"http:\/\/www.flickr.com\/photos\/26825745@N06\/5514359889\/\" title=\"sqlsample_1 by orczhou, on Flickr\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/farm6.static.flickr.com\/5097\/5514359889_820fb63088.jpg\" width=\"320\" height=\"205\" alt=\"sqlsample_1\" \/><\/a><\/p>\n<p>\u4e0a\u9762\u7684SQL\uff0c\u548b\u4e00\u773c\uff0c\u5f88\u96be\u770b\u51faSQL\u7684\u76ee\u7684\u662f\u4ec0\u4e48\u3002\u800c\u683c\u5f0f\u5316\u7684\u8f93\u51fa\u53ef\u4ee5\u8ba9SQL\u66f4\u6613\u8bfb\u61c2\uff0c\u5982\uff1a<\/p>\n<p><a href=\"http:\/\/www.flickr.com\/photos\/26825745@N06\/5366693389\/\" title=\"screenshot-sqlparser by orczhou, on Flickr\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/farm6.static.flickr.com\/5170\/5366693389_6f140df551.jpg\" width=\"401\" height=\"273\" alt=\"screenshot-sqlparser\" \/><\/a><\/p>\n<p>\u4e0a\u5468\u672b\u505a\u4e86\u4e00\u4e2a\u7b80\u5355\u7684<a href=\"http:\/\/www.orczhou.com\/sqlparser\/sqlbeautifier\/index.php\">PHP SQL Format<\/a>\u5de5\u5177\uff0c\u53ef\u4ee5\u5b9e\u73b0\u4e0a\u8ff0\u529f\u80fd\uff0c\u8fd9\u91cc\u7b80\u5355\u7684\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528<a href=\"http:\/\/www.orczhou.com\/sqlparser\/sqlbeautifier\/index.php\">PHP SQL Format<\/a>\uff08\u4e5f\u53ef\u4ee5\u53c2\u8003<a href=\"http:\/\/www.orczhou.com\/sqlparser\/\">\u8fd9\u91cc<\/a>\uff09\u3002<\/p>\n<div class=\"myt1\">1. \u4e0b\u8f7d<a href=\"http:\/\/code.google.com\/p\/php-sqlformat\/downloads\/list\">\u76f8\u5173\u6587\u4ef6<\/a>\u5e76\u89e3\u538b\u5230\u4f60\u7684WEB\u76ee\u5f55<\/div>\n<p>\u6709\u5982\u4e0b\u6587\u4ef6:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/www.orczhou.com\/wp-content\/uploads\/2011\/03\/libfiles.png\" alt=\"\" title=\"libfiles\" width=\"260\" height=\"157\" class=\"alignleft size-full wp-image-2865\" \/><\/p>\n<p>\u5c06\u8fd9\u4e9b\u6587\u4ef6\u90fd\u653e\u5165web\u76ee\u5f55\u4e0b\u7684sqlparserlib\u76ee\u5f55\u4e0b\u3002<\/p>\n<div class=\"myt1\">2. \u7f16\u5199\u5982\u4e0bPHP\/HTML\u4ee3\u7801<\/div>\n<pre><div class=\"mycode\">&#60;link rel=\"stylesheet\" type=\"text\/css\" href=\"sqlparserlib\/sqlsyntax.css\" \/&#62; \r\n&#60;?php\r\n     define('PARSER_LIB_ROOT', \"\/opt\/www\/sqlparserlib\/\");\r\n     require_once PARSER_LIB_ROOT.'sqlparser.lib.php';\r\n     function SQLFormatPHP($sql){\r\n        return PMA_SQP_formatHtml(PMA_SQP_parse($sql));\r\n     }\r\n     $sql = \"SELECT  FROM (select  from dual)\";\r\n     echo SQLFormatPHP($sql);\r\n ?&#62;\r\n<\/div><\/pre>\n<p>\u53ea\u8981\u628a\u4e0a\u9762php\u4ee3\u7801\u4e2d\u7684$sql\u6539\u6210\u4f60\u7684\u8f93\u5165SQL\u5c31OK\u4e86\u3002<\/p>\n<div class=\"myt1\">3. \u9700\u8981\u6ce8\u610f\u7684\u95ee\u9898<\/div>\n<p>* \u4e0a\u9762\u7684\u4ee3\u7801\u4e2d\uff0c\u8def\u5f84\u4e00\u5b9a\u8981\u6ce8\u610f\uff0c\u5728\u4f60\u7684\u4ee3\u7801\u4e2d\u4e5f\u5fc5\u987b\u5f15\u7528\u6b63\u786e\u7684\u8def\u5f84<\/p>\n<p>* \u4e0a\u9762\u7684sqlsyntax.css\u5b9a\u4e49\u4e86\u5f88\u591aCSS\uff0c\u6ce8\u610f\u4e0d\u8981\u4e0e\u4f60\u7684CSS\u51b2\u7a81\u4e86<\/p>\n<p>* \u4e0a\u9762require_once\u5f88\u591a\u51fd\u6570\uff0c\u6ce8\u610f\u4e0d\u8981\u4e0e\u4f60\u7684\u51fd\u6570\u51b2\u7a81\u4e86<\/p>\n<div class=\"myt1\">4. \u5b9e\u73b0\u8bf4\u660e<\/div>\n<p>\u8fd9\u91cc\u4f7f\u7528\u7684\u4ee3\u7801\u5305<a href=\"http:\/\/www.phpmyadmin.net\/phpdoc\/phpMyAdmin\/_libraries---sqlparser.lib.php.html\">sqlparser.lib.php<\/a>\u6765\u81ea<a href=\"http:\/\/www.phpmyadmin.net\/\">phpMyAdmin<\/a>\uff0c\u7a0d\u5fae\u505a\u4e86\u4e00\u4e9b\u6539\u52a8\uff0c\u8ba9\u8fd9\u5757\u4ee3\u7801\u80fd\u591f\u72ec\u7acb\u4f7f\u7528\u3002<\/p>\n<p>\u770b\u4e86<a href=\"http:\/\/stackoverflow.com\/questions\/2078661\/use-php-to-format-an-input-sql-query-as-html\">Stackoverflow<\/a>\u4e0a\u5f88\u591a\u670b\u53cb\u4e5f\u6709\u7c7b\u4f3c\u95ee\u9898\uff0c\u6240\u4ee5\u5c31\u82b1\u4e86\u51e0\u4e2a\u5c0f\u65f6\u7684\u5c1d\u8bd5\uff0c\u628a<a href=\"http:\/\/www.phpmyadmin.net\/\">phpMyAdmin<\/a>\u91cc\u9762SQL Parser\u76f8\u5173\u7684\u4ee3\u7801\u72ec\u7acb\u51fa\u6765\uff0clib\u4e2d\u6709\u5f88\u591a\u7684\u4ee3\u7801\u90fd\u5e94\u8be5\u662f\u65e0\u7528\u7684\uff0c\u6211\u5e76\u6ca1\u6709\u505a\u7cbe\u7b80\uff0c\u6240\u4ee5\u4f60\u6700\u6c42\u6548\u7387\u7684\u8bdd\uff0c\u53ef\u80fd\u9700\u8981\u81ea\u5df1\u518d\u4f18\u5316\u4e00\u4e0b\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>SQL Format,Open Source,SQL Beautifier<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_eb_attr":"","inline_featured_image":false,"_tocer_settings":[],"footnotes":""},"categories":[6,5],"tags":[],"class_list":["post-2858","post","type-post","status-publish","format-standard","hentry","category-mysql","category-code-staff"],"_links":{"self":[{"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/posts\/2858","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/comments?post=2858"}],"version-history":[{"count":15,"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/posts\/2858\/revisions"}],"predecessor-version":[{"id":2877,"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/posts\/2858\/revisions\/2877"}],"wp:attachment":[{"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/media?parent=2858"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/categories?post=2858"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.orczhou.com\/index.php\/wp-json\/wp\/v2\/tags?post=2858"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}