帝国论坛帝国网站管理系统交流区帝国CMS使用交流[原创]内容存文本模式转存数据库模式处理方法 【本版专题贴子】  
 1/2     1 2 ›› ›|
主题:[原创]内容存文本模式转存数据库模式处理方法 [加入收藏夹]   

夏威夷海盗
用户头衔:进士

精华贴   :1
发贴数   :737
经验值   :3017
注册时间:2005-10-17
信息 搜索 好友 发送悄悄话 精益求精-帝国网站管理系统7.5正式版开源发布】   [第 1 楼]
[原创]内容存文本模式转存数据库模式处理方法
估计很多朋友和我一样,当初为了尝鲜,把部分栏目转成了内容存文本的模式,现在不得不忍受着刷新页面时一会要调成存文本模式一会要取消.而实际上网站的内容根本就不用存文本,就几万条内容而已.

现在就放出昨天刚弄出来的转换代码,希望想恢复数据库存储内容的朋友能用得到.

步骤:

1.因为找了很久没有找到ECMS读取文本的函数,而且每一条数据都要查询和写入一次数据库,最好还是做一个本地环境,用自己的电脑来处理.我用的是APMServ,最新版可以在这里下载:http://apmserv.s135.com/

2.先备份数据库,保存到本地,备份帝国存文本的目录 /d/txt/ 到本地,目录最好也按照网站上的层次放置,如有变化,可以修改下面代码中的路径.

3.用帝国备份网恢复到本机一个数据库中,如代码中的babyucan

4.修改下面代码中的相关数据库配置.

5.运行提供的简易转换程序

6.提示处理完毕后,使用帝国备份王备份所处理的数据表,我写的代码中处理的是phome_ecms_news,然后把处理好的数据备份上传,恢复数据即可.

程序只针对newstext字段处理,所以处理完后只备份新闻数据表就可以了.

代码内容如下,大家可以先测试一下.



<?php
error_reporting(E_ERROR | E_WARNING | E_PARSE);

@set_time_limit(10000);//设置超时时间,越长越好

//********************* 程序开始 ********************

$kai = $_POST['kai'];

//配置数据库参数
mysql_connect("localhost","root","");//本机数据库用户名和密码
mysql_select_db("babyucan");//本机数据库名,
mysql_query("set names 'gb2312'");

//数据表第一条信息的ID
$a=mysql_query("select id from phome_ecms_news order by id asc limit 1");
$num1= mysql_result($a,0);

//数据表最后一条信息的ID
$b=mysql_query("select id from phome_ecms_news order by id desc limit 1");
$num2= mysql_result($b,0);

if ($kai==1){
//循环逐条处理
for($i=$num1;$i<$num2;$i++){

        $sql="select newstext from phome_ecms_news where id=".$i;

        if($result=mysql_query($sql)){
                $r=mysql_fetch_object($result);
                $text=$r->newstext;

                //判断是否是存文本的信息
                if (strlen($text)==42 && preg_match("/^[0-9a-z\d\/]*$/i",$text)){       
       
                $url="d/txt/".$text.".php";//因为帝国存文本中有exit中断,所以需要用读文件的方法去读取代码,文本的路径要正确,存在本文件所以目录下的子目录"d/txt/"下
                $temp=file($url);

                //echo substr($temp[0],12);

                //过滤帝国存文本生成的exit中断代码,使用文本中的内容替换数据库中相应的数据值
                $wurl="update phome_ecms_news set newstext='".substr($temp[0],12)."' where id=".$i;
                $write=mysql_db_query("babyucan",$wurl);
       
                }
        }
}

echo "OK,搞定!";

}

?>
<form method="post" action="index.php">
<input type=submit name=ok value="从<?=$num1?>开始处理,到<?=$num2?>结束.点击开始处理">
<input type=hidden name="kai" value=1>
</form>



上传以下附件:
[下载 *.rar](文件大小:1.03 KB,下载次数:125)

[该贴被修改 2 次,最后修改时间 2009-01-20 17:31:40 ]


抖音:babyucan
2009-01-19 16:43:36 已设置保密 顶部 回复 引用 报告 编辑 删除

flashjohn
用户头衔:探花

精华贴   :0
发贴数   :5519
经验值   :14211
注册时间:2007-11-27
信息 搜索 好友 发送悄悄话 免费开源-EBMA系统:更安全的MYSQL管理和备份系统】   [第 2 楼]





2009-01-19 16:46:30 已设置保密 顶部 回复 引用 报告 编辑 删除

zxzl
用户头衔:进士

精华贴   :0
发贴数   :617
经验值   :2498
注册时间:2008-04-07
信息 搜索 好友 发送悄悄话 精益求精-帝国网站管理系统7.5正式版开源发布】   [第 3 楼]

不得不忍受着刷新页面时一会要调成存文本模式一会要取消????

这是从何说起,我的怎么从来都不用




2009-01-19 16:52:33 已设置保密 顶部 回复 引用 报告 编辑 删除

夏威夷海盗
用户头衔:进士

精华贴   :1
发贴数   :737
经验值   :3017
注册时间:2005-10-17
信息 搜索 好友 发送悄悄话 免费开源-EBMA系统:更安全的MYSQL管理和备份系统】   [第 4 楼]

部分栏目存文本,部分没有存,



抖音:babyucan
2009-01-19 17:21:39 已设置保密 顶部 回复 引用 报告 编辑 删除

zxzl
用户头衔:进士

精华贴   :0
发贴数   :617
经验值   :2498
注册时间:2008-04-07
信息 搜索 好友 发送悄悄话 精益求精-帝国网站管理系统7.5正式版开源发布】   [第 5 楼]

部分栏目存文本,部分没有存,

就算这样刷新时也用不着调来调去啊,一键不就全部都刷新了???




2009-01-19 21:42:22 已设置保密 顶部 回复 引用 报告 编辑 删除

mydream
用户头衔:进士 *

精华贴   :0
发贴数   :384
经验值   :2109
注册时间:2007-12-27
信息 搜索 好友 发送悄悄话 免费开源-EBMA系统:更安全的MYSQL管理和备份系统】   [第 6 楼]

支持




2009-01-19 22:59:42 已设置保密 顶部 回复 引用 报告 编辑 删除

dont
用户头衔:进士

精华贴   :0
发贴数   :2140
经验值   :5059
注册时间:2008-02-26
信息 搜索 好友 发送悄悄话 精益求精-帝国网站管理系统7.5正式版开源发布】   [第 7 楼]

支持




2009-01-19 23:18:35 已设置保密 顶部 回复 引用 报告 编辑 删除

freeuser
用户头衔:秀才

精华贴   :0
发贴数   :193
经验值   :578
注册时间:2008-10-08
信息 搜索 好友 发送悄悄话 免费开源-EBMA系统:更安全的MYSQL管理和备份系统】   [第 8 楼]

祝大家新年快乐!




2009-01-19 23:24:49 已设置保密 顶部 回复 引用 报告 编辑 删除

tkf88
用户头衔:探花

精华贴   :0
发贴数   :8732
经验值   :22199
注册时间:2007-05-26
信息 搜索 好友 发送悄悄话 精益求精-帝国网站管理系统7.5正式版开源发布】   [第 9 楼]

收藏




2009-01-20 00:19:35 已设置保密 顶部 回复 引用 报告 编辑 删除

司徒新浪
用户头衔:举人

精华贴   :0
发贴数   :543
经验值   :1398
注册时间:2007-12-27
信息 搜索 好友 发送悄悄话 免费开源-EBMA系统:更安全的MYSQL管理和备份系统】   [第 10 楼]

不错,支持下




2009-01-20 09:33:31 已设置保密 顶部 回复 引用 报告 编辑 删除
 1/2     1 2 ›› ›|

快速回复
内容

表情
使用EBB代码 使用smile代码 显示签名 自动分析url 自动分析img
     【进入高级模式】   (按 Ctrl+Enter 直接提交)
    顶部  加入收藏夹
关于帝国 | 广告服务 | 联系我们 | 法律声明 | 隐私条款 | 许可协议
Powered by: EBB Version 2.2.1