首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle数据库管理
» order by sys_guid() 不生效
‹‹ 上一主题
|
下一主题 ››
18
1/2
1
2
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题: order by sys_guid() 不生效
liangmin11
资深会员
精华贴数 0
个人空间
0
技术积分 1666 (1029)
社区积分 300 (1949)
注册日期 2005-4-6
论坛徽章:5
#1
使用道具
发表于 2008-8-29 11:45
order by sys_guid() 不生效
RHEL4.5 + 10.2.0.2
select * from (select * from user_objects order by sys_guid()) where rownum<3;
语句不管用, 并不随机生成数据, 经过几个RHEL4.5+10.2.0.2的环境测试, 都是不生效, 但是在windwos系统下确实是管用的,
经过测试, 在我的环境下如下的方法是有用的!
select * from (select * from user_objects order by dbms_random.value) where rownum<3;
各位高手谁给解释一下, 这是为什么呢?
__________________
专业的ORACLE提问网, 中国的ASKTOM, www.askoracle.com.cn
只看该作者
liangmin11
资深会员
精华贴数 0
个人空间
0
技术积分 1666 (1029)
社区积分 300 (1949)
注册日期 2005-4-6
论坛徽章:5
#2
使用道具
发表于 2008-8-29 13:01
高手给看看
__________________
专业的ORACLE提问网, 中国的ASKTOM, www.askoracle.com.cn
只看该作者
Kamus
版主
精华贴数 51
个人空间
400
技术积分 46804 (13)
社区积分 3565 (391)
注册日期 2002-5-26
论坛徽章:30
#3
使用道具
发表于 2008-8-29 14:25
有趣的问题。我倒是有些诧异为什么order by sys_guid()或者order by dbms_random.value会有效。
select object_name from (select * from user_objects order by sys_guid()) where rownum<3;
select * from (select * from user_objects order by dbms_random.value) where rownum<3;
这两句确实都嫩正常运行,但是如果将sys_guid()或者dbms_random.value的值填入这个SQL,那肯定就报错了。所以分析的话还是应该从access path处入手吧。
__________________
有事情请发Gmail邮箱,站内IM可能不能及时回复。
***
Chanel [K]
***
从明天起, 做一个幸福的人
喂马, 劈柴, 周游世界
从明天起, 关心粮食和蔬菜
我有一所房子 面朝大海, 春暖花开
只看该作者
liangmin11
资深会员
精华贴数 0
个人空间
0
技术积分 1666 (1029)
社区积分 300 (1949)
注册日期 2005-4-6
论坛徽章:5
#4
使用道具
发表于 2008-8-29 14:28
order by dbms_random.value 确实是有效的, 目前通过测试, 在应用里上线正常使用了! order by sys_guid()我在之前的其他系统上也是使用正常的, 这次在RHEL4.5 10.2.0.2的系统就不行了!
__________________
专业的ORACLE提问网, 中国的ASKTOM, www.askoracle.com.cn
只看该作者
liangmin11
资深会员
精华贴数 0
个人空间
0
技术积分 1666 (1029)
社区积分 300 (1949)
注册日期 2005-4-6
论坛徽章:5
#5
使用道具
发表于 2008-8-29 14:29
[Copy to clipboard]
[
-
]
CODE:
select b.id,b.login_name,b.gender,b.age from
(select * from (
select id
from t
where t.gender = 1
and t.age = 22
and t.status = 1
order by dbms_random.value) where rownum <=30 ) a,
b
where a.id=b.id
如上语句确实有效
__________________
专业的ORACLE提问网, 中国的ASKTOM, www.askoracle.com.cn
只看该作者
Kamus
版主
精华贴数 51
个人空间
400
技术积分 46804 (13)
社区积分 3565 (391)
注册日期 2002-5-26
论坛徽章:30
#6
使用道具
发表于 2008-8-29 14:31
你说的order by sys_guid()在RH上无效了,是报错,还是一直都是返回同样的记录?
__________________
有事情请发Gmail邮箱,站内IM可能不能及时回复。
***
Chanel [K]
***
从明天起, 做一个幸福的人
喂马, 劈柴, 周游世界
从明天起, 关心粮食和蔬菜
我有一所房子 面朝大海, 春暖花开
只看该作者
liangmin11
资深会员
精华贴数 0
个人空间
0
技术积分 1666 (1029)
社区积分 300 (1949)
注册日期 2005-4-6
论坛徽章:5
#7
使用道具
发表于 2008-8-29 14:36
可以运行, 但是一直返回同样记录!
__________________
专业的ORACLE提问网, 中国的ASKTOM, www.askoracle.com.cn
只看该作者
Kamus
版主
精华贴数 51
个人空间
400
技术积分 46804 (13)
社区积分 3565 (391)
注册日期 2002-5-26
论坛徽章:30
#8
使用道具
发表于 2008-8-29 14:47
我刚才在Oracle XE 10.2.0.1 for Unbrealable Linux上也验证了,确实如你所说,始终返回同样的结果集。
我会发一封邮件去问一下,应该是不同平台对于sys_guid()实现方法不用导致的。
__________________
有事情请发Gmail邮箱,站内IM可能不能及时回复。
***
Chanel [K]
***
从明天起, 做一个幸福的人
喂马, 劈柴, 周游世界
从明天起, 关心粮食和蔬菜
我有一所房子 面朝大海, 春暖花开
只看该作者
liangmin11
资深会员
精华贴数 0
个人空间
0
技术积分 1666 (1029)
社区积分 300 (1949)
注册日期 2005-4-6
论坛徽章:5
#9
使用道具
发表于 2008-8-29 14:54
呵呵 感谢版主的帮助了! 等你的消息了.
谢谢
__________________
专业的ORACLE提问网, 中国的ASKTOM, www.askoracle.com.cn
只看该作者
Kamus
版主
精华贴数 51
个人空间
400
技术积分 46804 (13)
社区积分 3565 (391)
注册日期 2002-5-26
论坛徽章:30
#10
使用道具
发表于 2008-8-29 16:27
还没有回信,但是我比较了一下linux上和windows上的sys_guid()。
在linux和windows的oracle中分别执行:select sys_guid() from dual;
可以看到多次执行的结果,在windows中是变化的,但是在linux中始终是一样的,这是为什么在linux中不能用sys_guid(0来返回random结果集的原因。
__________________
有事情请发Gmail邮箱,站内IM可能不能及时回复。
***
Chanel [K]
***
从明天起, 做一个幸福的人
喂马, 劈柴, 周游世界
从明天起, 关心粮食和蔬菜
我有一所房子 面朝大海, 春暖花开
只看该作者
18
1/2
1
2
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Fusion中间件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> Oracle EBS R12
> PeopleSoft与JDE
> EBS相关文档
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 体育世界
> 体育博彩专版
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计