Mysql 通过使用用户付款表的连接更新约 10 万用户

标签 mysql sql database join sql-update

user and user_payment table structure are given as screenshot

当我执行插入查询时,这对我来说效果很好,并在 12 秒内插入了大约 94,000 条记录。查询如下。

insert into database1.user(username,id,password,date_created,last_updated)
select contact_email_id, user_id,user_password,rec_crt_date,rec_up_date from     database2.tbl_user group by contact_email_id;

但是当我尝试通过使用给定查询与 user_ payment 表连接来更新所有 94,000 个用户时:

UPDATE database1.user as t JOIN database2.tbl_user_payment as t1 
ON t.id = t1.user_id SET t.subscription_type=t1.subscription_type,    t.subscription_date=t1.subscription_date, t.subscription_expiry_date=t1.expiry_date;

当我执行此查询时,我没有收到任何响应或错误。我等了很长时间的回复(大约 1 小时,但我知道我不应该花超过几分钟),但没有得到任何回复。

非常感谢任何帮助

最佳答案

首先,要了解性能,最好在查询之前放置 explain 并了解生成的计划。

这是您的查询:

UPDATE cvsurgeon.user as t JOIN
       jellyfis_cvsurgeon.tbl_user_payment as t1 
       ON t.id = t1.user_id
    SET t.subscription_type=t1.subscription_type,
        t.subscription_date=t1.subscription_date,
        t.subscription_expiry_date=t1.expiry_date;

您的图像很难阅读,但我认为它在 jellyfis_cvsurgeon.user_id 上没有索引。查询确实需要该索引来提高性能。

另外,在编写update之前,我认为最好编写相应的selectselect 可能会遇到相同的性能问题,您可以在启动修改数据的查询之前修复它。

关于Mysql 通过使用用户付款表的连接更新约 10 万用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24059342/

相关文章:

mysql - 根据两个不同表中的条目自动填充sql表

mysql - 是否应该在用户可以选择多个选项的结构中使用外键?如果是这样,怎么会这样?

mysql - 如何根据学号在联结表上进行选择

php - 如何从 MySQL 表中删除重复项?

MySQL - 组中的条件选择

mysql - 将所有相似的文本分组到不同的组中

python - 在数据库中插入和读取数据

php - 在设定的到期时间(例如 5 分钟)后删除数据库行

mysql - 如何通过按类型或 ID 区分该列,将一列值显示到多列中

mysql - 将多行值合并为单行值