帝国cms在有数据时进行id重排的方法
时间:2023年10月20日
/来源:网络
/编辑:佚名
在使用帝国cms管理文章时,有时我们会对某些文章进行删除,这就造成了部分id的确实,例如自增的文章id已经排到68547,而实际库内只有61500篇文章,对使用没有任何影响,但某些强迫症同学感觉受不了,希望重排id,所以有了下面的教程。
注:本教程只适合新站!!!因为修改后会导致前台文章页面变化,影响seo!
一、我们以帝国cms的新闻表为例,新闻表相关表共有8个数据表,按照副表分表情况可能更多。表名如下:
phome_ecms_news
phome_ecms_news_check
phome_ecms_news_check_data
phome_ecms_news_data_1
phome_ecms_news_doc
phome_ecms_news_doc_data
phome_ecms_news_doc_index
phome_ecms_news_index
二、首先我们需要备份相关数据表,防止出错,可在帝国cms后台 - 系统 - 备份与数据恢复 - 备份数据,或在phpmyadmin中直接将相关数据表导出为sql文件。
三、首先我们将每个有数据的数据表中,都建立oldid字段,把数据表的id字段复制到oldid字段,保留原来的id值用于校验。语句如下:
update phome_ecms_news set oldid=id;
四、将news表中的id字段删除,而后重新添加重新添加id字段,并将id字段设置为第一位,主键模式,自增,这样就实现了重排。然后修改数据表,将下一个自增id值修改为新的。涉及语句如下:
ALTER TABLE `phome_ecms_news` DROP `id`;
ALTER TABLE `phome_ecms_news` ADD `id` INT( 10 ) NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST ;
五、news_index索引表,将id字段删除,新建id字段,其他同上。
ALTER TABLE `phome_ecms_news_index` DROP `id`;
ALTER TABLE `phome_ecms_news_index` ADD `id` INT( 10 ) NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST ;
六、校验数据,如存在classid不对应的问题,后台点击修改信息会出现提示链接不存在,例如news表中某信息classid=5,news_index表中classid=6,则需要进行classid更新,语句如下:
UPDATE phome_ecms_news_index p, phome_ecms_news pp SET p.classid = pp.classid WHERE p.id = pp.id;
七、id重排后,数据表中的文章路径titleurl字段、filename字段还没变,执行以下语句替换。
update phome_ecms_news set filename=id;
update phome_ecms_news set titleurl=replace(titleurl,oldid,id);
八,步骤完成,我们进行最终校验,查看文章链接等是否有异常,无误后完成。
注:本教程只适合新站!!!因为修改后会导致前台文章页面变化,影响seo!
一、我们以帝国cms的新闻表为例,新闻表相关表共有8个数据表,按照副表分表情况可能更多。表名如下:
phome_ecms_news
phome_ecms_news_check
phome_ecms_news_check_data
phome_ecms_news_data_1
phome_ecms_news_doc
phome_ecms_news_doc_data
phome_ecms_news_doc_index
phome_ecms_news_index
二、首先我们需要备份相关数据表,防止出错,可在帝国cms后台 - 系统 - 备份与数据恢复 - 备份数据,或在phpmyadmin中直接将相关数据表导出为sql文件。
三、首先我们将每个有数据的数据表中,都建立oldid字段,把数据表的id字段复制到oldid字段,保留原来的id值用于校验。语句如下:
update phome_ecms_news set oldid=id;
四、将news表中的id字段删除,而后重新添加重新添加id字段,并将id字段设置为第一位,主键模式,自增,这样就实现了重排。然后修改数据表,将下一个自增id值修改为新的。涉及语句如下:
ALTER TABLE `phome_ecms_news` DROP `id`;
ALTER TABLE `phome_ecms_news` ADD `id` INT( 10 ) NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST ;
五、news_index索引表,将id字段删除,新建id字段,其他同上。
ALTER TABLE `phome_ecms_news_index` DROP `id`;
ALTER TABLE `phome_ecms_news_index` ADD `id` INT( 10 ) NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST ;
六、校验数据,如存在classid不对应的问题,后台点击修改信息会出现提示链接不存在,例如news表中某信息classid=5,news_index表中classid=6,则需要进行classid更新,语句如下:
UPDATE phome_ecms_news_index p, phome_ecms_news pp SET p.classid = pp.classid WHERE p.id = pp.id;
七、id重排后,数据表中的文章路径titleurl字段、filename字段还没变,执行以下语句替换。
update phome_ecms_news set filename=id;
update phome_ecms_news set titleurl=replace(titleurl,oldid,id);
八,步骤完成,我们进行最终校验,查看文章链接等是否有异常,无误后完成。
新闻资讯 更多
- 【帝国cms教程】帝国CMS模板变量$GLOBALS[navclassid]用法分析04-03
- 【帝国cms教程】鲜为人知帝国CMS内容页调用上一篇和下一篇的精华方法汇总04-03
- 【帝国cms教程】怎么快速找出帝国CMS数据库配置文件路径及迁移网站后修改技巧!04-03
- 【帝国cms教程】帝国CMS模板$GLOBALS[navclassid]用法详解04-03
- 【帝国cms教程】帝国cms 7.5版列表页分页样式修改笔记04-02
- 【帝国cms教程】解决帝国CMS搜索页面模板不支持灵动标签和万能标签的方法04-02
- 【帝国cms教程】帝国CMS只备份栏目和模板的方法04-02
- 【帝国cms教程】帝国CMS怎样删除清空数据库记录?04-02
热门文章
- 178Moban源码谈谈免费源码与收费源码的区别
- 2帝国CMS忘记后台登陆用户名、密码、认证码的解决方法
- 3帝国CMS(EmpireCMS) v7.5后台任意代码执行漏洞及具体修复方法
- 4帝国CMS和WordPress 哪个好?哪个适合建站?
- 5如何解决Discuz的密码错误次数过多请15分钟后登陆的问题
- 6帝国cms灵动标签取得内容和栏目链接地址
- 7emlog pro 注册码“开心”教程(如果有一天,emlog官方版 或者 emlog免费版 跑路了,那用户怎么办?)
- 8织梦CMS在nginx下设置伪静态方法(附nginx伪静态规则)
- 9帝国cms后台登录出现”您还未登录”怎么解决?
- 10帝国cms7.5忘记登录密码 和忘记登录认证码以及多次登录 失败被锁定解决办法