|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- <?php
- /**
- * 数据库操作替换
- *
- * @version $Id: sys_data_replace.php 1 22:28 2010年7月20日Z tianya $
- * @package DedeBIZ.Administrator
- * @copyright Copyright (c) 2022, DedeBIZ.COM
- * @license https://www.dedebiz.com/license
- * @link https://www.dedebiz.com
- */
- require_once(dirname(__FILE__).'/config.php');
- CheckPurview('sys_Data');
- if (empty($action)) $action = '';
- if (empty($action)) {
- require_once(DEDEADMIN."/templets/sys_data_replace.htm");
- exit();
- }
-
- /*-------------------------------
- //列出数据库表里的字段
- function __getfields()
- --------------------------------*/
- else if ($action == 'getfields') {
- AjaxHead();
- $dsql->GetTableFields($exptable);
- echo "<div style='border:1px solid #ababab;background-color:#FEFFF0;margin-top:6px;padding:3px;line-height:160%'>";
- echo "表(".$exptable.")含有的字段:<br>";
- while ($row = $dsql->GetFieldObject()) {
- echo "<a href=\"javascript:pf('{$row->name}')\">".$row->name."</a>\r\n";
- }
- echo "</div>";
- exit();
- }
- /*-------------------------------
- //保存用户设置,清空会员数据
- function __Apply()
- --------------------------------*/
- else if ($action == 'apply') {
- $validate = empty($validate) ? '' : strtolower($validate);
- $svali = GetCkVdValue();
- if ($validate == "" || $validate != $svali) {
- ShowMsg("安全确认码不正确!", "javascript:;");
- exit();
- }
- if ($exptable == '' || $rpfield == '') {
- ShowMsg("请指定数据表和字段", "javascript:;");
- exit();
- }
- if ($rpstring == '') {
- ShowMsg("请指定被替换内容", "javascript:;");
- exit();
- }
- if ($rptype == 'replace') {
- $condition = empty($condition) ? '' : " WHERE $condition ";
- $rs = $dsql->ExecuteNoneQuery("UPDATE $exptable SET $rpfield=REPLACE($rpfield,'$rpstring','$tostring') $condition ");
- $dsql->ExecuteNoneQuery("OPTIMIZE TABLE `$exptable`");
- if ($rs) {
- ShowMsg("成功完成数据替换", "javascript:;");
- exit();
- } else {
- ShowMsg("数据替换失败", "javascript:;");
- exit();
- }
- } else {
- $condition = empty($condition) ? '' : " And $condition ";
- $rpstring = stripslashes($rpstring);
- $rpstring2 = str_replace("\\", "\\\\", $rpstring);
- $rpstring2 = str_replace("'", "\\'", $rpstring2);
- $dsql->SetQuery("SELECT $keyfield,$rpfield FROM $exptable WHERE $rpfield REGEXP '$rpstring2' $condition ");
- $dsql->Execute();
- $tt = $dsql->GetTotalRow();
- if ($tt == 0) {
- ShowMsg("根据您指定的正则,找不到任何东西", "javascript:;");
- exit();
- }
- $oo = 0;
- while ($row = $dsql->GetArray()) {
- $kid = $row[$keyfield];
- $rpf = preg_replace("#".$rpstring."#i", $tostring, $row[$rpfield]);
- $rs = $dsql->ExecuteNoneQuery("UPDATE $exptable SET $rpfield='$rpf' WHERE $keyfield='$kid' ");
- if ($rs) {
- $oo++;
- }
- }
- $dsql->ExecuteNoneQuery("OPTIMIZE TABLE `$exptable`");
- ShowMsg("共找到 $tt 条记录,成功替换了 $oo 条", "javascript:;");
- exit();
- }
- }
|