Database.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. <?php
  2. namespace app\admin\controller\general;
  3. use app\common\controller\Backend;
  4. use think\Db;
  5. use think\Debug;
  6. /**
  7. * 数据库管理
  8. *
  9. * @icon fa fa-database
  10. * @remark 可在线进行一些简单的数据库表优化或修复,查看表结构和数据。也可以进行SQL语句的操作
  11. */
  12. class Database extends Backend
  13. {
  14. /**
  15. * 查看
  16. */
  17. function index()
  18. {
  19. $tables_data_length = $tables_index_length = $tables_free_length = $tables_data_count = 0;
  20. $tables = $list = [];
  21. $list = Db::query("SHOW TABLES");
  22. foreach ($list as $key => $row)
  23. {
  24. $tables[] = ['name' => reset($row), 'rows' => 0];
  25. }
  26. $data['tables'] = $tables;
  27. $data['saved_sql'] = [];
  28. $this->view->assign($data);
  29. return $this->view->fetch();
  30. }
  31. /**
  32. * SQL查询
  33. */
  34. public function query()
  35. {
  36. $do_action = $this->request->post('do_action');
  37. echo '<style type="text/css">
  38. xmp,body{margin:0;padding:0;line-height:18px;font-size:12px;font-family:"Helvetica Neue", Helvetica, Microsoft Yahei, Hiragino Sans GB, WenQuanYi Micro Hei, sans-serif;}
  39. hr{height:1px;margin:5px 1px;background:#e3e3e3;border:none;}
  40. </style>';
  41. if ($do_action == '')
  42. exit(__('Invalid parameters'));
  43. $tablename = $this->request->post("tablename/a");
  44. if (in_array($do_action, array('doquery', 'optimizeall', 'repairall')))
  45. {
  46. $this->$do_action();
  47. }
  48. else if (count($tablename) == 0)
  49. {
  50. exit(__('Invalid parameters'));
  51. }
  52. else
  53. {
  54. foreach ($tablename as $table)
  55. {
  56. $this->$do_action($table);
  57. echo "<br />";
  58. }
  59. }
  60. }
  61. private function viewinfo($name)
  62. {
  63. $row = Db::query("SHOW CREATE TABLE `{$name}`");
  64. $row = array_values($row[0]);
  65. $info = $row[1];
  66. echo "<xmp>{$info};</xmp>";
  67. }
  68. private function viewdata($name = '')
  69. {
  70. $sqlquery = "SELECT * FROM `{$name}`";
  71. $this->doquery($sqlquery);
  72. }
  73. private function optimize($name = '')
  74. {
  75. if (Db::execute("OPTIMIZE TABLE `{$name}`"))
  76. {
  77. echo __('Optimize table %s done', $name);
  78. }
  79. else
  80. {
  81. echo __('Optimize table %s fail', $name);
  82. }
  83. }
  84. private function optimizeall($name = '')
  85. {
  86. $list = Db::query("SHOW TABLES");
  87. foreach ($list as $key => $row)
  88. {
  89. $name = reset($row);
  90. if (Db::execute("OPTIMIZE TABLE {$name}"))
  91. {
  92. echo __('Optimize table %s done', $name);
  93. }
  94. else
  95. {
  96. echo __('Optimize table %s fail', $name);
  97. }
  98. echo "<br />";
  99. }
  100. }
  101. private function repair($name = '')
  102. {
  103. if (Db::execute("REPAIR TABLE `{$name}`"))
  104. {
  105. echo __('Repair table %s done', $name);
  106. }
  107. else
  108. {
  109. echo __('Repair table %s fail', $name);
  110. }
  111. }
  112. private function repairall($name = '')
  113. {
  114. $list = Db::query("SHOW TABLES");
  115. foreach ($list as $key => $row)
  116. {
  117. $name = reset($row);
  118. if (Db::execute("REPAIR TABLE {$name}"))
  119. {
  120. echo __('Repair table %s done', $name);
  121. }
  122. else
  123. {
  124. echo __('Repair table %s fail', $name);
  125. }
  126. echo "<br />";
  127. }
  128. }
  129. private function doquery($sql = null)
  130. {
  131. $sqlquery = $sql ? $sql : $this->request->post('sqlquery');
  132. if ($sqlquery == '')
  133. exit(__('SQL can not be empty'));
  134. $sqlquery = str_replace("\r", "", $sqlquery);
  135. $sqls = preg_split("/;[ \t]{0,}\n/i", $sqlquery);
  136. $maxreturn = 100;
  137. $r = '';
  138. foreach ($sqls as $key => $val)
  139. {
  140. if (trim($val) == '')
  141. continue;
  142. $val = rtrim($val, ';');
  143. $r .= "SQL:<span style='color:green;'>{$val}</span> ";
  144. if (preg_match("/^(select|explain)(.*)/i ", $val))
  145. {
  146. Debug::remark("begin");
  147. $limit = stripos(strtolower($val), "limit") !== false ? true : false;
  148. $count = Db::execute($val);
  149. if ($count > 0)
  150. {
  151. $resultlist = Db::query($val . (!$limit && $count > $maxreturn ? ' LIMIT ' . $maxreturn : ''));
  152. }
  153. else
  154. {
  155. $resultlist = [];
  156. }
  157. Debug::remark("end");
  158. $time = Debug::getRangeTime('begin', 'end', 4);
  159. $usedseconds = __('Query took %s seconds', $time) . "<br />";
  160. if ($count <= 0)
  161. {
  162. $r .= __('Query returned an empty result');
  163. }
  164. else
  165. {
  166. $r .= (__('Total:%s', $count) . (!$limit && $count > $maxreturn ? ',' . __('Max output:%s', $maxreturn) : ""));
  167. }
  168. $r = $r . ',' . $usedseconds;
  169. $j = 0;
  170. foreach ($resultlist as $m => $n)
  171. {
  172. $j++;
  173. if (!$limit && $j > $maxreturn)
  174. break;
  175. $r .= "<hr/>";
  176. $r .= "<font color='red'>" . __('Row:%s', $j) . "</font><br />";
  177. foreach ($n as $k => $v)
  178. {
  179. $r .= "<font color='blue'>{$k}:</font>{$v}<br/>\r\n";
  180. }
  181. }
  182. }
  183. else
  184. {
  185. Debug::remark("begin");
  186. $count = Db::execute($val);
  187. Debug::remark("end");
  188. $time = Debug::getRangeTime('begin', 'end', 4);
  189. $r .= __('Query affected %s rows and took %s seconds', $count, $time) . "<br />";
  190. }
  191. }
  192. echo $r;
  193. }
  194. }