Database.php 6.6 KB

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