V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
Kei001
V2EX  ›  MySQL

如何批量替换 MySQL 中 PHP 序列化后的数据

  •  
  •   Kei001 · 2020-05-19 23:00:12 +08:00 · 2822 次点击
    这是一个创建于 1649 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我有一些数据是用 php 数组序列化后存储在 MySQL 中,现在想在数据库里替换掉数组中的一些字符串内容。

    比方说,我现在序列化数组中有包含了 www.aa.com ,现在想把它批量替换成 www.aaa.com

    UPDATE wp_postmeta SET meta_value = replace(meta_value, 'http://www.aa.com', 'http://www.aaa.com')

    无法直接用这条 MySQL 命令直接改,因为 php 序列化数组还包含了字符串长度,替换会增加字符串长度而导致不匹配无法正常反序列化。

    求教各位大佬有没有其他方法解决这个问题。

    2 条回复    2020-05-20 09:48:03 +08:00
    foam
        1
    foam  
       2020-05-20 00:43:52 +08:00 via Android
    别想那么多,用脚本读出来,修改后再写回去。
    hsk9044
        2
    hsk9044  
       2020-05-20 09:48:03 +08:00
    最好还是读出来反序列化再写回去, 因为替换序列化后的文本复杂度肯定比较高, 这个时候不管是从性能的角度还是从开发速度的角度, 用 sql 语句的效率都没有直接用程序写的高
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1172 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 43ms · UTC 18:34 · PVG 02:34 · LAX 10:34 · JFK 13:34
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.