[求助] sql 正则批量修改

2020-06-12 14:45:36 +08:00
 Vibra

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

数据库中怎么批量把 user_1@xxx.com 换成 user_1@yyy.com 呢?

2040 次点击
所在节点    程序员
9 条回复
Telegram
2020-06-12 14:58:23 +08:00
需要正则吗?不是有 replace 函数吗?

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

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

完工
iceecream
2020-06-12 16:44:21 +08:00
不说数据量,怎么搞
nuistzhou
2020-06-12 19:54:56 +08:00
建议非万不得已不要碰正则,SQL 的 Replace 函数很方便呀。
pyu77
2020-06-13 17:33:35 +08:00
如果是 oracle 数据库,大数据量导出比较麻烦,导入可以用 sqlloader 。
不过还是建议直接字符串替换就可以了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/680984

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX