查看: 21|回复: 0

[教程] 织梦DEDECMS分表迁移内容模型转入新建模型的方法

[复制链接]

2

主题

0

回帖

0

积分

热心网友

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2008-11-29
发表于 2023-10-16 00:00:00 | 显示全部楼层 |阅读模式

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语句均使用的默认数据库前缀,如您的数据库前缀做过自定义,需修改为您自定义的数据库前缀。另外,所有操作请先备份在做操作!

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部