您现在的位置是:首页 > 教程 > 帝国CMS教程帝国CMS教程
帝国CMS报错Duplicate entry 'xx' for key 'PRIMARY'的解决方法
春竹2023-05-06 23:31:33帝国CMS教程已有人查阅
导读帝国CMS后台添加信息报错Duplicate entry 'xx' for key 'PRIMARY',出现以下代码,这种帝国CMS报错是因为ecms_news_index索引数字不对,索引ID“3261”的信息已经存在。
帝国CMS后台添加信息报错Duplicate entry 'xx' for key 'PRIMARY',出现以下代码
Duplicate entry '3261' for key 'PRIMARY'insert into ***_ecms_news_index(classid,checked,newstime,truetime,lastdotime,havehtml) values('1','1','1446087639','1446087687','1446087687','1');
这种帝国CMS报错是因为ecms_news_index索引数字不对,索引ID“3261”的信息已经存在,后添加的信息索引ID必须大于“3261”才行。照成这种错误一般是后台丢失数据,导致索引无法正常递增混乱。
方法1:后台修复数据库
如果进的了后台尝试后台修复数据库,点击 后台 系统 备份与恢复数据 备份数据
拉到最下面 点击修复数据表和优化数据表即可
方法2:插入一个大于当前索引的信息
如果后台修复没有用,那我们就来手动或SQL插入一个大于“3261”等等信息,让索引ID重新递增。
手动操作直接参考数据库的信息,ID填一个大于“3261”的即可。
SQL插入看下面代码
INSERT INTO `phome_ecms_news` VALUES (3262, 1, 1, '', '', '', 1, 'admin', '', 1, 0, 1333244472, 0, 1, 0, 0, ',b|', '', '1', 0, 0, 0, 0, 0, 0, '企业11111', 1333244427, '', 0, 1, 1350716513, 0, 0, 0, 0, '', '企业理念:诚信、专业、高效 星兴财务rn', 0, '1', '', 0, '', 0);
第一个字段“3262”就是索引ID,后面的参考自己的字段调整。
方法3:批量重新生成索引
如果以上都不行,只能用SQL想办法让索引ID重新生成一遍,建议分条执行,一是避免超时,二是能发现错误
CREATE TABLE [!db.pre!]ecms_newstemp AS(SELECT id,classid,newstime,truetime,lastdotime,havehtml FROM [!db.pre!]ecms_news);
ALTER TABLE `[!db.pre!]ecms_newstemp` ADD COLUMN `checked` tinyint(1) not null DEFAULT 0 AFTER `classid`;
ALTER TABLE `[!db.pre!]ecms_newstemp` add primary key (id);
alter table [!db.pre!]ecms_news_index rename to [!db.pre!]ecms_news_indexbak;
alter table [!db.pre!]ecms_newstemp rename to [!db.pre!]ecms_news_index;
ALTERTABLE`[!db.pre!]ecms_news_index`CHANGE`id``id`INT(10)NOTNULLAUTO_INCREMENT;
alter table [!db.pre!]ecms_news_index add index(classid);
alter table [!db.pre!]ecms_news_index add index(checked);
alter table [!db.pre!]ecms_news_index add index(newstime);
alter table [!db.pre!]ecms_news_index add index(truetime);
update [!db.pre!]ecms_news_index set checked=1;
本文标签:
很赞哦! ()
相关文章
随机图文
-
帝国cms整合CKPlayer播放器教程步骤
帝国cms7.5整合CKPlayer播放器教程说明,将帝国cms7.5编辑器整合CKPlayer播放器,支持一个页面多个视频播放 -
帝国CMS编辑器怎么调整默认高度的方法
很多小伙伴有很多特殊需求,比如说调整下后台编辑器的高度,让可视范围更大一些,更方便添加信息。小编统一回复一下:就是再后台模型修改字段可以设置高宽度。 -
帝国CMS模板解决标题和副标题自动判断显示的方法
再帝国CMS模板制作中有这种需求:自动判断发的内容有没有副标题,如果有副标题就显示副标题,没有就显示标题的情况! -
帝国CMS列表内容模板(list.var)调用会员头像会员名和文章标题以及连接
{$dbtbpre}enewsmemberadd 会员数据库附表,存放了会员的头像等信息,$listtemp='代码内容'; 列表内容使用PHP必须使用的语法,记得勾选使用程序代码
留言与评论 (共有 条评论) |