V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Vibra
V2EX  ›  程序员

[求助] sql 正则批量修改

  •  
  •   Vibra · 2020-06-12 14:45:36 +08:00 · 2004 次点击
    这是一个创建于 1386 天前的主题,其中的信息可能已经有所发展或是发生改变。

    公司现在有一个需求, 迁移邮箱

    数据库中怎么批量把 [email protected] 换成 [email protected] 呢?

    9 条回复    2020-06-13 17:33:35 +08:00
    Telegram
        1
    Telegram  
       2020-06-12 14:58:23 +08:00
    需要正则吗?不是有 replace 函数吗?

    update 表名 set email= replace(email,'xxx.com','yyy.com');
    zlygr
        2
    zlygr  
       2020-06-12 15:03:20 +08:00
    oracle 还是 mysql?
    oracle 有一个字符切割 INSTR 函数可以按照 @字符切割然后再||拼接后半段
    mysql 用 SUBSTRING_INDEX 函数试试
    icchux
        3
    icchux  
       2020-06-12 15:23:32 +08:00
    一楼的方法不行么。。。既然是公司,邮箱后缀应该一样吧
    LennieChoi
        4
    LennieChoi  
       2020-06-12 15:52:41 +08:00
    直接改啊,或者加一列新列保存。如果是公司邮箱的话,只存个用户名不就 OK 了? 后缀需要吗?
    saulshao
        5
    saulshao  
       2020-06-12 16:04:03 +08:00
    从表里面把数据读出来,用循环替换一遍,然后再 update 回去不就得了?
    xlcoder166
        6
    xlcoder166  
       2020-06-12 16:09:07 +08:00
    无视究竟是那种原始数据库

    1. 仅导出该用户表
    2. 打开 vim 或其他编辑器 %s/@xxx.com/@yyy.com/gc
    3. 导入

    完工
    iceecream
        7
    iceecream  
       2020-06-12 16:44:21 +08:00
    不说数据量,怎么搞
    nuistzhou
        8
    nuistzhou  
       2020-06-12 19:54:56 +08:00
    建议非万不得已不要碰正则,SQL 的 Replace 函数很方便呀。
    pyu77
        9
    pyu77  
       2020-06-13 17:33:35 +08:00
    如果是 oracle 数据库,大数据量导出比较麻烦,导入可以用 sqlloader 。
    不过还是建议直接字符串替换就可以了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5310 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 07:12 · PVG 15:12 · LAX 00:12 · JFK 03:12
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.