比如有一个张表,order 表一般查询的是最近 3 个月的记录,但是保留了 1 年的记录。
现在我想把 order 表中创建时间是 3 个月之后的记录,导入到 old_order 表中。
我自己想到的办法是撸代码,一条记录一条记录的复制过去,然后删队原始数据 。
你们一般的做法是什么?
1
nybux 2017-06-16 16:40:00 +08:00 1
不用一条条吧,直接 where 一个时间条件,用 insert into ... select 就可以了
|
2
littleylv 2017-06-16 16:44:20 +08:00
1 楼说的对
|
3
chenqh OP @nybux 但是这个样子会变成手动的对吧,我的想法是变成定时任务那样 ,每天跑一点,省得我每天手动去弄,有可能某天就出错了呢
|
4
nybux 2017-06-16 16:55:09 +08:00
写成脚本,然后由 crontab 去定时调用
|
5
jianzhiyao020 2017-06-16 16:55:56 +08:00
可以这样子,
按照时间分表, 新表数据量少, 建索引量少, 插入、检索速度快。 冷热可以这样区分。 |
6
2ME 2017-06-16 16:57:11 +08:00 1
同 1 楼 一样可以定时任务 where 条件的时间灵活一点就好了
|
7
yanze0613 2017-06-16 17:17:26 +08:00 1
insert into ... select,限制每次读取的行数 然后写进 crontab
|
8
bk201 2017-06-16 17:29:08 +08:00 1
你还不如 3 个月就换一次表名来得快捷
|
10
snail00 2017-06-16 17:38:49 +08:00 1
写个存储过程, 然后用 mysql 的事件去定时执行, 我现在就在撸这个.
|
12
noNOno 2017-06-16 18:03:51 +08:00
时间字段上建个聚集索引不行么
|