随机获取oracle数据库中的任意一行数据(rownum)示例介绍


本文整理自网络,侵删。

最近看oracle资料的时候,了解rownum的概念,以前只知道对数据库表进行简单的增删改查;

看到了rownum的概念后,突然想到了好多业务场景应该都可以适用的,比如在进行随机发奖的时候,

我们就可以从先查一下奖品表中可以发的总奖品数,然后通过java的Random类在总奖品数内生成一个随机整数X,然后调用

select * from (select rownum no,id from Table where rownum<=X ) where no >=X

获取出该条奖品,这样获取出来的值,在一定的并发量的时候,发生拿到同一条数据的概率就比较小啦,为了支持高并发的情况,可以在考虑为奖品表增加一个乐观锁,

如果真的发生了同一条奖品被同时操作的时候,有了乐观锁,在奖品已经被发之后,另外的一个进程再来发这个奖就会抛出异常org.hibernate.StaleObjectStateException,然后我们就可以通过捕获异常,然后重新给这个用户去奖品表里面来获取奖品!

大致介绍一下rownum的使用吧!很多文章都介绍啦!

对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,且rownum不能以任何表的名称作为前缀。

1. rownum 对于等于某值的查询条件

select rownum,id,name from student where rownum=1;这个是可以查出第一行数据的,但是当rownum不为1时,是无法查询出来数据的;如

select rownum,id,name from student where rownum =2;这个就无法查询出数据;

2.rownum对于大于某值的查询条件

select * from(select rownum no ,id,name from student) where no>2;查询rownum大于某值时,必须要使用子查询的方式才可以,且内部的select中的rownum必须使用别名,否则外部查询条件是无法正常定位rownum是指内部的rownum

阅读剩余部分

相关阅读 >>

怎么安装oracle

oracle在plsql中使用存储过程

oracle数据库sql的优化总结

oracle portal及其门户网站开发概述

asp.net oracle数据的通用操作类

win7下oracle 10g安装图文教程

ibatis组合oracle的iterate insert批量插入

如何修改oracle数据库用户密码?

mysql和oracle的区别是什么

oracle批量查询、删除、更新使用bulk collect提高效率

更多相关阅读请进入《oracle》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...