善恶资源网专注优秀技术教程分享网-傅汉松!

帝国CMS后台添加信息报错Duplicate entry 'xx' for key 'PRIMARY

傅汉松 技术教程

汉松出品|资源介绍

傅汉松本次为大家分享的是帝国CMS后台添加信息报错Duplicate entry 'xx' for key 'PRIMARY

傅汉松

  帝国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, '帝国cms模板', 1333244427, '', 0, 1, 1350716513, 0, 0, 0, 0, '', '老鱼网', 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;


标签: 暂无标签

免责声明:

本站提供的资源,都来自网络,版权争议与本站无关,所有内容及软件的文章仅限用于学习和研究目的。不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负,我们不保证内容的长久可用性,通过使用本站内容随之而来的风险与本站无关,您必须在下载后的24个小时之内,从您的电脑/手机中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。侵删请致信E-mail:321976193@qq.com

同类推荐
评论列表

技术教程 帝国CMS后台添加信息报错Duplicate entry 'xx' for key 'PRIMARY
  帝国CMS后台添加信息报错Duplicate entry 'xx' for key 'PRIMARY',出现以下代码Dupl...
扫描二维码阅读原文
QQ娱乐网 January, 01
生成社交图 ×
    94.46ms