Database.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace app\model\system;
  11. use think\facade\Db;
  12. use app\model\BaseModel;
  13. /**
  14. * 数据库操作
  15. */
  16. class Database extends BaseModel
  17. {
  18. public $backup_path = __UPLOAD__ . '/dbsql';
  19. /***********************************************************SQL开始*********************************************************/
  20. /**
  21. * 修复表
  22. */
  23. public function repair($tables)
  24. {
  25. if ($tables) {
  26. Db::startTrans();
  27. try {
  28. if (is_array($tables)) {
  29. $tables = implode('`,`', $tables);
  30. Db::query("REPAIR TABLE `{$tables}`");
  31. } else {
  32. Db::query("REPAIR TABLE `{$tables}`");
  33. }
  34. Db::commit();
  35. return $this->success(1);
  36. } catch (\Exception $e) {
  37. // 回滚事务
  38. Db::rollback();
  39. return $this->error('', "DABASE_REPAIR_FAIL");
  40. }
  41. } else {
  42. return $this->error('', "DABASE_REPAIR_FAIL");
  43. }
  44. }
  45. /**
  46. * 优化表
  47. */
  48. public function optimize($tables)
  49. {
  50. if ($tables) {
  51. if (is_array($tables)) {
  52. $tables = implode('`,`', $tables);
  53. $list = Db::query("OPTIMIZE TABLE `{$tables}`");
  54. if ($list) {
  55. return $this->success(1);
  56. } else {
  57. return $this->error('', "DATABASE_OPTIMIZE_FAIL");
  58. }
  59. } else {
  60. $list = Db::query("OPTIMIZE TABLE `{$tables}`");
  61. if ($list) {
  62. return $this->success(1);
  63. } else {
  64. return $this->error('', "DATABASE_OPTIMIZE_FAIL");
  65. }
  66. }
  67. } else {
  68. return $this->error('', "REQUEST_DATABASE_TABLE");
  69. }
  70. }
  71. private function sql_execute($sql, $is_debug)
  72. {
  73. if (trim($sql) != '') {
  74. $sql = str_replace("\r\n", "\n", $sql);
  75. $sql = str_replace("\r", "\n", $sql);
  76. $sql_array = explode(";\n", $sql);
  77. if (!$is_debug) {
  78. Db::startTrans();
  79. }
  80. try {
  81. foreach ($sql_array as $item) {
  82. if ($is_debug) {
  83. Db::startTrans();
  84. }
  85. $querySql = trim($item);
  86. if ($querySql != '') {
  87. @Db::execute($querySql . ";");
  88. if ($is_debug) {
  89. Db::rollback();
  90. }
  91. }
  92. }
  93. if (!$is_debug) {
  94. Db::commit();
  95. }
  96. return $this->success(1);
  97. } catch (\Exception $e) {
  98. Db::rollback();
  99. return $this->error($e->getMessage());
  100. }
  101. } else {
  102. return $this->error('');
  103. }
  104. }
  105. /**
  106. * 执行sql
  107. */
  108. public function sqlQuery($sql)
  109. {
  110. $result = $this->sql_execute($sql, false);
  111. return $result;
  112. }
  113. public function yujjia($sql)
  114. {
  115. Db::startTrans();
  116. try {
  117. Db::query($sql);
  118. Db::rollback();
  119. return "1";
  120. } catch (\Exception $e) {
  121. Db::rollback();
  122. return $this->error($e->getMessage());
  123. }
  124. }
  125. /**
  126. * 查询所有表
  127. */
  128. public function getDatabaseList()
  129. {
  130. $databaseList = Db::query("SHOW TABLE STATUS");
  131. return $databaseList;
  132. }
  133. /**备份数据库语句
  134. * @return string
  135. */
  136. public function backupSql($tables, $id, $start)
  137. {
  138. }
  139. public function getTableSchemas($table)
  140. {
  141. $mysql = "DROP TABLE IF EXISTS `$table`;\r\n";
  142. $temp_create_table_result = Db::query("show create table `$table`");
  143. $create_table = $temp_create_table_result[0]['Create Table'];
  144. $mysql .= $create_table . ";\r\n";
  145. return $mysql;
  146. }
  147. public function getTableInsertSql($tablename, $start, $size)
  148. {
  149. $data = '';
  150. $tmp = '';
  151. $sql = "SELECT * FROM `{$tablename}` LIMIT {$start}, {$size}";
  152. $result = Db::query($sql);
  153. if (!empty($result)) {
  154. foreach ($result as $row) {
  155. $tmp .= '(';
  156. foreach ($row as $k => $v) {
  157. $value = str_replace(array('\\', "\0", "\n", "\r", "'", '"', "\x1a"), array('\\\\', '\\0', '\\n', '\\r', "\\'", '\\"', '\\Z'), $v);
  158. $tmp .= "'" . $value . "',";
  159. }
  160. $tmp = rtrim($tmp, ',');
  161. $tmp .= "),\n";
  162. }
  163. $tmp = rtrim($tmp, ",\n");
  164. $data .= "INSERT INTO `{$tablename}` VALUES \n{$tmp};\n";
  165. $datas = array(
  166. 'data' => $data,
  167. 'result' => $result,
  168. );
  169. return $datas;
  170. } else {
  171. return false;
  172. }
  173. }
  174. /**
  175. * 格式化字节大小
  176. *
  177. * @param number $size
  178. * 字节数
  179. * @param string $delimiter
  180. * 数字和单位分隔符
  181. * @return string 格式化后的带单位的大小
  182. * @author
  183. *
  184. */
  185. public function format_bytes($size, $delimiter = '')
  186. {
  187. $units = array(
  188. 'B',
  189. 'KB',
  190. 'MB',
  191. 'GB',
  192. 'TB',
  193. 'PB'
  194. );
  195. for ($i = 0; $size >= 1024 && $i < 5; $i++)
  196. $size /= 1024;
  197. return round($size, 2) . $delimiter . $units[$i];
  198. }
  199. /**
  200. * 多维数组排序
  201. */
  202. public function my_array_multisort($data, $sort_order_field, $sort_order = SORT_DESC, $sort_type = SORT_NUMERIC)
  203. {
  204. foreach ($data as $val) {
  205. $key_arrays[] = $val[$sort_order_field];
  206. }
  207. array_multisort($key_arrays, $sort_order, $sort_type, $data);
  208. return $data;
  209. }
  210. /***********************************************************SQL结束*********************************************************/
  211. }