DEDE站点一大,文章一多,就会发现前期没规划好,没进行分表,造成数据库庞大臃肿,执行效率低了。这个时候,其实还可以补救,就是对频道进行分表操作,将你网站的一个个频道新建一个个模型,用来对应不同的数据库表进行分表操作。这里涉及到数据库操作,因此需要备份下数据库必加保险。
首先在织梦后台建立新内容模型 ,(核心-频道模型-内容模型管理-然后复制文章模型或者你要用的某个模型)再用以下的MYSQL 语句 将以前的栏目文章转入新模型,
假设以前的栏目为文章模型,栏目ID 为 31,新建模型ID为7(默认的文章模型为1,模型ID可以在内容模型管理最左侧看到),使用新建模型建立的新文章栏目ID为52,数据库中新模型附加表为dede_addonarticle17
执行以下操作
1、将原模型下的ID31的栏目内的全部内容转移到新模型dede_addonarticle17
INSERT INTO dede_addonarticle17(aid,typeid,redirecturl,userip,body) SELECT aid,typeid,redirecturl,userip,body FROM dede_addonarticle where dede_addonarticle.typeid =31
2、删除原栏目下的全部内容(已经复制一份到新模型下了)
DELETE FROM `dede_addonarticle` WHERE typeid =31
3、将关联模型的地方全部改写一遍,将原来定义栏目ID31对应的频道模型全部由1改成7
update dede_arctiny set channel=7 where typeid=31
update dede_archives set channel=7 where typeid=31
update dede_arctype set channeltype =7 where id =31
4、修改关联栏目,将原来调用31号栏目的地方,全部改为52号栏目
update dede_addonarticle17 set typeid=52 where typeid=31
update dede_archives set typeid=52 where typeid=31
update dede_arctiny set typeid=52 where typeid=31
5、删除旧栏目
DELETE FROM dede_arctype WHERE id=31
以上则是织梦DEDECMS分表迁移内容模型转入新建模型的方法的全部内容,需要注意的是,所有sql语句均使用的默认数据库前缀,如您的数据库前缀做过自定义,需修改为您自定义的数据库前缀。另外,所有操作请先备份在做操作!