国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

119 lines
4.1KB

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
  6. <title>数据批量替换</title>
  7. <link rel="stylesheet" href="/static/web/css/font-awesome.min.css">
  8. <link rel="stylesheet" href="/static/web/css/bootstrap.min.css">
  9. <link rel="stylesheet" href="/static/web/css/admin.css">
  10. <script src="/static/web/js/jquery.min.js"></script>
  11. <script src="/static/web/js/bootstrap.min.js"></script>
  12. <script src="/static/web/js/webajax.js"></script>
  13. <script src="/static/web/js/admin.main.js"></script>
  14. </head>
  15. <body>
  16. <form action="sys_data_replace.php" name="form1" method="post" target="stafrm" onSubmit="return CheckSubmit();">
  17. <input type="hidden" name="action" value="apply">
  18. <table align="center" class="table maintable my-3">
  19. <tr>
  20. <td bgcolor="#f8fafb" colspan="2">数据库字段替换</td>
  21. </tr>
  22. <tr>
  23. <td colspan="2">
  24. <div class="alert alert-warning mb-0">数据库字段批量替换,修改不当会导致数据出错</div>
  25. </td>
  26. </tr>
  27. <tr>
  28. <td width="260">数据表与字段:</td>
  29. <td>
  30. <?php
  31. $dsql->SetQuery("Show Tables");
  32. $dsql->Execute('t');
  33. if ($dsql->GetError()!=''){
  34. echo "找不到您所指定的数据库".$dbname."";
  35. echo $qbutton;
  36. }
  37. echo "<select name='exptable' multiple='yes' onchange='ShowFields();' id='exptable' class='admin-input-lg mb-3'>";
  38. while($row = $dsql->GetArray('t',MYSQL_BOTH)){
  39. echo "<option value='{$row[0]}'>{$row[0]}</option>";
  40. }
  41. echo "</select>";
  42. $dsql->Close();
  43. ?>
  44. <div id="fields"></div>
  45. <input type="text" name="rpfield" id="rpfield" class="admin-input-sm">
  46. </td>
  47. </tr>
  48. <tr>
  49. <td>主键字段:</td>
  50. <td>
  51. <input type="text" name="keyfield" id="keyfield" class="admin-input-sm">
  52. <label><input type="radio" name="rptype" id="ot1" value="replace" checked> 普通替换</label>
  53. <label><input type="radio" name="rptype" id="ot2" value="regex"> 正则表达式</label>
  54. </td>
  55. </tr>
  56. <tr>
  57. <td>被替换值:</td>
  58. <td><textarea name="rpstring" id="rpstring" class="admin-textarea-xl"></textarea></td>
  59. </tr>
  60. <tr>
  61. <td>值替换为:</td>
  62. <td><textarea name="tostring" id="tostring" class="admin-textarea-xl"></textarea></td>
  63. </tr>
  64. <tr>
  65. <td>替换条件:</td>
  66. <td>
  67. <input type="text" name="condition" id="condition" class="admin-input-sm">
  68. <span>(不填写则完全替换)</span>
  69. </td>
  70. </tr>
  71. <tr>
  72. <td>验证码:</td>
  73. <td>
  74. <input type="text" name="validate" class="admin-input-sm text-uppercase">
  75. <img src="<?php echo $cfg_phpurl;?>/vdimgck.php" onclick="this.src='<?php echo $cfg_phpurl;?>/vdimgck.php?'+new Date().getTime()+Math.round(Math.random() * 10000)" title="验证码">
  76. </td>
  77. </tr>
  78. <tr>
  79. <td bgcolor="#f8f9fa" colspan="2" align="center"><button type="submit" name="submit" class="btn btn-success btn-sm">开始替换数据</button></td>
  80. </tr>
  81. <tr>
  82. <td colspan="2" id="mtd">
  83. <div id="mdv" class="admin-win-iframe"><iframe name="stafrm" frameborder="0" id="stafrm" width="100%" height="100%"></iframe></div>
  84. </td>
  85. </tr>
  86. </table>
  87. </form>
  88. <script>
  89. function ShowFields() {
  90. var exptable = $DE('exptable').options[$DE('exptable').selectedIndex].value;
  91. var queryUrl = "sys_data_replace.php?exptable=" + exptable + "&action=getfields";
  92. fetch(queryUrl).then(resp => {
  93. if (resp.ok) {
  94. return resp.text()
  95. }
  96. throw new Error('x');
  97. }).then((d) => {
  98. $DE('fields').innerHTML = d;
  99. }).catch((error) => {
  100. $DE('fields').innerHTML = errMsg;
  101. });
  102. }
  103. function CheckSubmit() {
  104. if ($DE('rpfield').value == "") {
  105. ShowMsg("您选择的操作为手工指定字段,但您并没指定");
  106. return false;
  107. }
  108. if ($DE('rpstring').value == "") {
  109. ShowMsg("您没指定要替换的字符串");
  110. return false;
  111. }
  112. return true;
  113. }
  114. function pf(v) {
  115. $DE('rpfield').value = v;
  116. }
  117. </script>
  118. </body>
  119. </html>