帝国cms有数据时进行id重排的方法,只适合新站!

2021-02-1317:30:01网站建设与开发Comments1,659 views字数 1299阅读模式

帝国cms管理文章时,有时我们会对某些文章进行删除,这就造成了部分id的确实,例如自增的文章id已经排到68547,而实际库内只有61500篇文章,对使用没有任何影响,但某些强迫症同学感觉受不了,希望重排id,所以有了下面的教程。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

注:本教程只适合新站!!!因为修改后会导致前台文章页面变化,影响seo!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

一、我们以帝国cms的新闻表为例,新闻表相关表共有8个数据表,按照副表分表情况可能更多。表名如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news_check文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news_check_data文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news_data_1文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news_doc文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news_doc_data文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news_doc_index文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

phome_ecms_news_index

二、首先我们需要备份相关数据表,防止出错,可在帝国cms后台 - 系统 - 备份与数据恢复 - 备份数据,或在phpmyadmin中直接将相关数据表导出为sql文件。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

三、首先我们将每个有数据的数据表中,都建立oldid字段,把数据表的id字段复制到oldid字段,保留原来的id值用于校验。语句如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

update phome_ecms_news set oldid=id;

四、将news表中的id字段删除,而后重新添加重新添加id字段,并将id字段设置为第一位,主键模式,自增,这样就实现了重排。然后修改数据表,将下一个自增id值修改为新的。涉及语句如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

ALTER TABLE  `phome_ecms_news` DROP  `id`;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

ALTER TABLE  `phome_ecms_news` ADD  `id` INT( 10 ) NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST ;

五、news_index索引表,将id字段删除,新建id字段,其他同上。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

ALTER TABLE  `phome_ecms_news_index` DROP  `id`;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

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更新,语句如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

UPDATE phome_ecms_news_index p, phome_ecms_news pp SET p.classid = pp.classid WHERE p.id = pp.id;

七、id重排后,数据表中的文章路径titleurl字段、filename字段还没变,执行以下语句替换。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

update phome_ecms_news set filename=id;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

update phome_ecms_news set titleurl=replace(titleurl,oldid,id);

八,步骤完成,我们进行最终校验,查看文章链接等是否有异常,无误后完成。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/20958.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/cms/20958.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定