oracle中如何删除第十条及以后的所有记录

没有id列,我用deletefromtablewhererownum>10,但是不行。不行。。。。... 没有id列,
我用delete from table where rownum>10,但是不行。
不行。。。。
展开
 我来答
woshidaniel
2015-10-08 · TA获得超过9241个赞
知道小有建树答主
回答量:1760
采纳率:96%
帮助的人:943万
展开全部

oracle每条记录都有一个唯一的物理记录rowid,可以通过rowid作为唯一主键进行删除。

1、首先根据rownum编号

SELECT ROWID,ROWNUM RN FROM 表

2、筛选rn>=10的记录的rowid

SELECT ROWID FROM (SELECT ROWID,ROWNUM RN FROM 表) WHERE RN>=10

3、根据rowid删除第十条以及以后的记录

DELETE FROM 表 where rowid in(SELECT ROWID FROM (SELECT ROWID,ROWNUM RN FROM 表) WHERE RN>=10)
今至电子科技有限公司
2024-08-23 广告
上海今至电子科技有限公司,是一家从事运维服务、系统集成和网络工程的专业公司。业务涵盖IT解决方案、网络工程、应用软件开发、系统集成、服务器虚拟化、桌面虚拟化、高性能运算、负载均衡、数据容灾备份、服务外包、IT运维等。我们的理念:诚信为本,服... 点击进入详情页
本回答由今至电子科技有限公司提供
lllmouse
2010-08-13 · TA获得超过3660个赞
知道小有建树答主
回答量:805
采纳率:0%
帮助的人:963万
展开全部
试试:
delete 表名 where rowid not in (select * from (select rowid from 表名 order by dbms_random.random) where rownum<10);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
vinson_shen
2010-08-13 · TA获得超过2503个赞
知道小有建树答主
回答量:960
采纳率:100%
帮助的人:0
展开全部
delete from tb_name where rowid not in (select rowid from tb_name where rownum<10)
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
fan601428
2010-08-13 · TA获得超过113个赞
知道答主
回答量:105
采纳率:0%
帮助的人:0
展开全部
delete from table b where b.rowid in(
select a.rowid
from
(select rowid,排序字段,rownum
from table
where rownum >=10
order by 排序字段)a)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
穆亚枫
2015-09-11 · TA获得超过210个赞
知道小有建树答主
回答量:285
采纳率:100%
帮助的人:165万
展开全部
DELETE FROM TABLE
WHERE ROWNUM>10
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式