zblog网站数据转移到帝国cms中的出现标签tags-id.html转换为tags/id/ 存储执行替换命令
时间:2023年12月10日
/来源:网络
/编辑:佚名
zblog网站数据转移到帝国cms中的出现标签tags-id.html转换为tags/id/,最简单的是用mysql正则替换 ,
update phome_ecms_news_data_1 SET newstext=REGEXP_REPLACE(newstext,'tags-([0-9]+)\.html','tags/$1/');
但是本地数据库版本不支持,不想升级数据库,于是小编写了一个存储过程执行这个功能,sql代码如下
DELIMITER $$
CREATE PROCEDURE my_procedure()
BEGIN
DECLARE i INT DEFAULT 1;
WHILE (i <= 16476) DO
update phome_ecms_news_data_1 SET newstext=REPLACE(newstext,'tags-i.html','tags/i/');
SET i = i + 1;
END WHILE;
END$$
DELIMITER ;
call my_procedure();
运行时间比较长,最好是空闲时间或者流量少的凌晨执行。
DELIMITER $$
CREATE PROCEDURE my_procedure(a INT)
BEGIN
DECLARE i INT DEFAULT 1;
WHILE (i <= a) DO
update phome_ecms_news_data_1 SET newstext=REPLACE(newstext,'tags-i.html','tags/i/');
SET i = i + 1;
END WHILE;
END$$
DELIMITER ;
call my_procedure(16476);
完善版
DELIMITER $$
CREATE PROCEDURE my_procedure(a INT)
BEGIN
DECLARE i INT DEFAULT 1;
WHILE (i <= a) DO
update phome_ecms_news_data_1 SET newstext=REPLACE(newstext,CONCAT('tags-',i,'.html'),CONCAT('tags/',i,'/'));
SET i = i + 1;
END WHILE;
END$$
DELIMITER ;
call my_procedure(16476);
如果上面的存储过程错误,可以删除后再建立存储过程。
删除存储过程
drop procedure my_procedure;
drop procedure if exists my_procedure;
update phome_ecms_news_data_1 SET newstext=REGEXP_REPLACE(newstext,'tags-([0-9]+)\.html','tags/$1/');
但是本地数据库版本不支持,不想升级数据库,于是小编写了一个存储过程执行这个功能,sql代码如下
DELIMITER $$
CREATE PROCEDURE my_procedure()
BEGIN
DECLARE i INT DEFAULT 1;
WHILE (i <= 16476) DO
update phome_ecms_news_data_1 SET newstext=REPLACE(newstext,'tags-i.html','tags/i/');
SET i = i + 1;
END WHILE;
END$$
DELIMITER ;
call my_procedure();
运行时间比较长,最好是空闲时间或者流量少的凌晨执行。
DELIMITER $$
CREATE PROCEDURE my_procedure(a INT)
BEGIN
DECLARE i INT DEFAULT 1;
WHILE (i <= a) DO
update phome_ecms_news_data_1 SET newstext=REPLACE(newstext,'tags-i.html','tags/i/');
SET i = i + 1;
END WHILE;
END$$
DELIMITER ;
call my_procedure(16476);
完善版
DELIMITER $$
CREATE PROCEDURE my_procedure(a INT)
BEGIN
DECLARE i INT DEFAULT 1;
WHILE (i <= a) DO
update phome_ecms_news_data_1 SET newstext=REPLACE(newstext,CONCAT('tags-',i,'.html'),CONCAT('tags/',i,'/'));
SET i = i + 1;
END WHILE;
END$$
DELIMITER ;
call my_procedure(16476);
如果上面的存储过程错误,可以删除后再建立存储过程。
删除存储过程
drop procedure my_procedure;
drop procedure if exists my_procedure;
新闻资讯 更多
- 【帝国cms教程】帝国CMS模板变量$GLOBALS[navclassid]用法分析04-03
- 【帝国cms教程】鲜为人知帝国CMS内容页调用上一篇和下一篇的精华方法汇总04-03
- 【帝国cms教程】怎么快速找出帝国CMS数据库配置文件路径及迁移网站后修改技巧!04-03
- 【帝国cms教程】帝国CMS模板$GLOBALS[navclassid]用法详解04-03
- 【帝国cms教程】帝国cms 7.5版列表页分页样式修改笔记04-02
- 【帝国cms教程】解决帝国CMS搜索页面模板不支持灵动标签和万能标签的方法04-02
- 【帝国cms教程】帝国CMS只备份栏目和模板的方法04-02
- 【帝国cms教程】帝国CMS怎样删除清空数据库记录?04-02
热门文章
- 178Moban源码谈谈免费源码与收费源码的区别
- 2帝国CMS忘记后台登陆用户名、密码、认证码的解决方法
- 3帝国CMS(EmpireCMS) v7.5后台任意代码执行漏洞及具体修复方法
- 4帝国CMS和WordPress 哪个好?哪个适合建站?
- 5如何解决Discuz的密码错误次数过多请15分钟后登陆的问题
- 6帝国cms灵动标签取得内容和栏目链接地址
- 7emlog pro 注册码“开心”教程(如果有一天,emlog官方版 或者 emlog免费版 跑路了,那用户怎么办?)
- 8织梦CMS在nginx下设置伪静态方法(附nginx伪静态规则)
- 9帝国cms后台登录出现”您还未登录”怎么解决?
- 10帝国cms7.5忘记登录密码 和忘记登录认证码以及多次登录 失败被锁定解决办法