请教一个关于循环的问题,删除数据

jakenlian 2015-07-29 06:08:53
我有一张有数千万数据的大表,现在想删掉一些没用的历史数据,如果用常规删法的话,会很慢,如:
delete from table_a t where t.id<5000000;
我的表有5个字段,其中id有索引。
删了两个小时,也没有完成。

考虑了一下,想用一个过程,让服务器自己空闲的时候,自己去删:

create or replace procedure self_procedure is
begin
for v in 4805000000 .. 4810000000 loop
delete from SYS2SYN_DATA_DETAIL t where t.master_id = v;
commit;
end loop;
end;

这样没似乎可以实现,但是每次只删除一条,不知道会删到什么时候,而且磁盘操作似乎有些频繁。
于是想一次多删除一些:

create or replace procedure self_procedure_muti is
begin
for v in 4805000000 .. 4810000000 loop
delete from SYS2SYN_DATA_DETAIL t where t.master_id < v;
v:=v+1000;
commit;
end loop;
end;

可是这个过程报错了,“表达式v不能用作赋值目标”。

请问,各位有什么好的办法没有?
...全文
234 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
滇中倦客 2015-07-31
  • 打赏
  • 举报
回复
使用forall,批量提交delete语句:
create or replace procedure self_del_syn_data_detail is
v number(19);
type tb_table_type is table of tmp_tab%rowtype index by binary_integer;

tb_table tb_table_type;
begin
for i in 4805000000 .. 4810000000 loop
tb_table(i).id := i;
end loop;
forall v in 1 .. tb_table.count
delete from SYS2SYN_DATA_DETAIL t where t.master_id = v + 4805000000;
commit;
end;
  • 打赏
  • 举报
回复
引用 3 楼 jakenlian 的回复:
这样实现了: create or replace procedure self_del_syn_data_detail is v number(19); begin for v in 0 .. 5000000 loop delete from SYS2SYN_DATA_DETAIL t where t.master_id = v + 4805000000; commit; end loop; end;
一条一条删除数据是比较慢的,最好是批量化删除,一次删除个1w条左右,速度还是蛮快的。 下面版主的方法很好,而且很简单,通过rownum可以起到限制 每次只删除几千条数据。
xu176032 2015-07-30
  • 打赏
  • 举报
回复
上一阵刚做了一个类似这种删除的优化,建议游标里查询一下rowid,然后配合上order by ,循环里面根据这个rowid去删除,速度会快很多,内存占用也可以,我们试过超千万级的数据~
chengccy 2015-07-30
  • 打赏
  • 举报
回复
如果表没有外键,在非占用时候可以用create+rename
小灰狼W 2015-07-29
  • 打赏
  • 举报
回复
其实最简单的:

begin

loop
delete from SYS2SYN_DATA_DETAIL where t.id<5000000 and rownum<=5000;
exit when sql%notfound;
commit;
end loop;
end;
/

rownum<=后面就是一次删的行数。id<5000000的全部删完,跳出循环
jakenlian 2015-07-29
  • 打赏
  • 举报
回复
这样实现了: create or replace procedure self_del_syn_data_detail is v number(19); begin for v in 0 .. 5000000 loop delete from SYS2SYN_DATA_DETAIL t where t.master_id = v + 4805000000; commit; end loop; end;
jakenlian 2015-07-29
  • 打赏
  • 举报
回复
在FOR循环中可能会遇到ORA-01426,主要是由于起始值或者结束值超过了2147483647,默认情况下
FOR 循环的数值需要 在-2147483648 到 2147483647之间,否则就会报错。

二楼的问题解决了:
http://blog.chinaunix.net/uid-22948773-id-3047969.html
jakenlian 2015-07-29
  • 打赏
  • 举报
回复
补充一句,我的这个过程,在建的时候没有报错。但是执行的时候,报错“ora-01426数字溢出”
C++课程设计-单链表——学生信息管理系统全文共9页,当前为第1页。C++课程设计 单链表——学生信息管理系统 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第1页。 学生信息管理系统设计文档 设计任务描述 为了实现学籍管理的简单化,我们基于Visual C++集成开发环境编写了"学生信息管理系统"软件,该软件适用于所有windows操作系统,面向广大用户,界面简洁,操作简单。此软件主要是实现对学生学籍信息进行系统化的管理,可以对学生基本信息进行添加、删除、查找、修改以及对学生成绩的管理,主要是根据学生的学号及其姓名进行操作的。该软件可以更加方便管理者管理学生学籍信息。 功能需求说明 该系统所需要的功能有:1、链表的建立; 2、学生信息的插入; 3、学生信息的查询; 4、学生信息的输出; 5、学生信息的修改; 6、学生信息的删除; 7、良好的欢迎选择界面。 三、总体方案设计 一、实现任务的方法 1、在欢迎选择界面中,使用Switch 这一选择结构来连接程序的执行和用户的命令; 2、在从学生信息的建立直到删除,都是使用链表的相关知识; 3、在定义学生信息时,建立一个Inform 类;在定义学生课程成绩时,自定义了一个achieve 结构体; 总体结构 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第2页。 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第2页。 三、模块划分 (1)链表的建立。 (2)对链表信息的插入。 (3)对链表信息的查找。 (4)对链表信息的输出。 (5)对链表信息的删除。 (6)对链表信息的修改。 课程成绩信息作为附加信息,穿插于各个模块中。 数据结构说明 一、自定义的数据结构: 1、achieve(课程成绩)用于存放课程成绩信息包括课程数、课程名、成绩、学分、总分和平均分。 2、inform(学生基本信息)用于存放学生基本信息,包括姓名、学号、性别等。 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第3页。3、结点结构-Nodetype,定义了数据域inform和指针域next; C++课程设计-单链表——学生信息管理系统全文共9页,当前为第3页。 二、类 Student 用于存放处理学生信息的各个功能函数,private 成员是链表的头指针。 各模块设计说明 一、建立: 首先:建立一个空链表: Student::Student() {head=new Nodetype; head->next=NULL; 表明这是一个空链表 cout<<"请建立链表\n"; } C++课程设计-单链表——学生信息管理系统全文共9页,当前为第4页。然后建立链表: C++课程设计-单链表——学生信息管理系统全文共9页,当前为第4页。 二、添加:按照学号从小到大的顺序插入: 三、输出:将链表的数据输出,由于上述操作,输出时会按照学号从小到大的顺序输出。 四、查找:利用学号和姓名两种方式进行查找,查找时主要是遍历链表进行判断 while(p!=NULL&&(d==1&&strcmp(input,p->data.num)!=0)""(d==2&&strcmp(input,p->data.name)!=0)) {p=p->next; } //遍历链表查找符合要求的节点 五、删除:利用节点的删除操作,找到链表中第i-1个结点,修改其指向后继的指针: q = p->next; p->next = q->next; delete(q); 六、更改:利用查找的操作,查到后在进行重新输入的操作; 测试情况说明 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第5页。测试一:学生信息的输入和输出都正常,但是查找、删除和修改时都只能对第一个数据进行操作,如下图所示: C++课程设计-单链表——学生信息管理系统全文共9页,当前为第5页。 但是当要进行查找、删除、修改操作时,系统只能对第一个对象进行操作 查看程序时,发现查找函数、删除和修改函数都有个逻辑错误 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第6页。全部修改后,程序的上述错误就没再出现了。 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第6页。 错误二:当提示是否输入课程成绩信息时,输入第一门课程名时,会出现无穷循环 但当输入第一门课程后就会出现下图所示状况: 对于这种状况,我百思不得其解,后来请教其他同学,他告诉我错误在于声明课程成绩信息时出错了 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第7页。应该为二维数组,修改之后,课程成绩输入输出便正常了 C++课程设计-单链表——学生信息管理系统全文共9页,当前为第7页。 错误三:输入学生信息时不按照学号大小顺序,输出结果时也不

3,490

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 高级技术相关讨论专区
社区管理员
  • 高级技术社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧