首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle专题深入讨论
» 一直有个疑问,也一直没做试验,希望和大家一起讨论。。。
‹‹ 上一主题
|
下一主题 ››
26
1/3
1
2
3
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[原创]
一直有个疑问,也一直没做试验,希望和大家一起讨论。。。
sqysl
孤独剑客
来自 山东
精华贴数 0
个人空间
0
技术积分 1258 (1379)
社区积分 31 (6182)
注册日期 2006-12-20
论坛徽章:0
#1
使用道具
发表于 2008-5-22 16:57
一直有个疑问,也一直没做试验,希望和大家一起讨论。。。
问题是:delete from test where 1=2这个语句会在回滚段里分配一个事务槽吗?会在数据段里或数据段里的块上分配信息吗?如果只修改了块的头信息,象:ITL,块的版本号怎末发生变化?存在只修改块头信息而不修改块里数据的情况呢?一起讨论。
__________________
曾经沧海难为水,除却巫山不是云。
天若有情天亦老,人间正道是沧桑。
只看该作者
Yong Huang
版主
精华贴数 2
个人空间
0
技术积分 4168 (339)
社区积分 129 (2998)
注册日期 2001-10-9
论坛徽章:6
#2
使用道具
发表于 2008-5-23 01:54
No. It does not. Oracle knows you're not getting any rows.
Yong Huang
只看该作者
sqysl
孤独剑客
来自 山东
精华贴数 0
个人空间
0
技术积分 1258 (1379)
社区积分 31 (6182)
注册日期 2006-12-20
论坛徽章:0
#3
使用道具
发表于 2008-5-23 07:54
thanks for reply,yong huang
__________________
曾经沧海难为水,除却巫山不是云。
天若有情天亦老,人间正道是沧桑。
只看该作者
*迎风*
精华贴数 0
个人空间
0
技术积分 244 (7898)
社区积分 133 (2963)
注册日期 2002-7-8
论坛徽章:0
#4
使用道具
发表于 2008-5-23 13:39
to Yong Huang
How to oracle know it not getting any rows?
只看该作者
晶晶小妹
月是上弦
精华贴数 3
个人空间
6470
技术积分 1845 (892)
社区积分 9 (11681)
注册日期 2008-2-15
论坛徽章:2
#5
使用道具
发表于 2008-5-23 15:30
一个简单的实验即要证明此点:
sid=39 pid=17> delete gk where 0=1;
已删除0行。
sid=43 pid=21> select * from v$transaction;
未选定行
v$transaction视图没有任何行,也就是ORACLE不认为这是一个事务的开始。
我的测试环境是10g
__________________
没有必胜的秘籍,没有方程式遵循
要赢~只有全身心的投入!
为了方便大家查阅,所有的文章都已转入空间
http://space.itpub.net/?13095417
请大家多多支持!
只看该作者
Toms_zhang
会员
精华贴数 1
个人空间
0
技术积分 16891 (58)
社区积分 2046 (588)
注册日期 2002-8-31
论坛徽章:46
#6
使用道具
发表于 2008-5-23 15:48
QUOTE:
原帖由
晶晶小妹
于 2008-5-23 15:30 发表
一个简单的实验即要证明此点:
sid=39 pid=17> delete gk where 0=1;
已删除0行。
sid=43 pid=21> select * from v$transaction;
未选定行
v$transaction视图没有任何行,也就是ORACLE不认为这是一个事务的开始。
我的测试环境是10g
are you sure?
__________________
托马斯张
MSN:
toms_zrp@live.cn
我的BLOG:
http://tomszrp.itpub.net
只看该作者
晶晶小妹
月是上弦
精华贴数 3
个人空间
6470
技术积分 1845 (892)
社区积分 9 (11681)
注册日期 2008-2-15
论坛徽章:2
#7
使用道具
发表于 2008-5-23 16:00
这个实验是我刚做的。
你是不是说:v$transaction中没有行,并不能说明一个事务没有开始。
__________________
没有必胜的秘籍,没有方程式遵循
要赢~只有全身心的投入!
为了方便大家查阅,所有的文章都已转入空间
http://space.itpub.net/?13095417
请大家多多支持!
只看该作者
sqysl
孤独剑客
来自 山东
精华贴数 0
个人空间
0
技术积分 1258 (1379)
社区积分 31 (6182)
注册日期 2006-12-20
论坛徽章:0
#8
使用道具
发表于 2008-5-23 18:19
以前也和他们讨论过这件事情,我也查了视图资料,V$TRANSACTION,这个视图确实是只显示目前活着的事务,这里没有事务,并不等于一个事务没发生过(V$TRANSACTION lists the active transactions in the system.),你可以查查V$session.TADDR,该字段存储的是事务对象的信息,这个字段在运行了该语句后会产生值的,所以,对这个简单的问题一直比较迷惑,现在谁能把DELETE FROM TEST WHERE 1=2这个语句的内在执行过程清楚的给出就好了,然后可以顺着这个过程做个测试。
[
本帖最后由 sqysl 于 2008-5-23 18:29 编辑
]
__________________
曾经沧海难为水,除却巫山不是云。
天若有情天亦老,人间正道是沧桑。
只看该作者
Yong Huang
版主
精华贴数 2
个人空间
0
技术积分 4168 (339)
社区积分 129 (2998)
注册日期 2001-10-9
论坛徽章:6
#9
使用道具
发表于 2008-5-24 01:55
QUOTE:
原帖由
sqysl
于 2008-5-23 04:19 发表
以前也和他们讨论过这件事情,我也查了视图资料,V$TRANSACTION,这个视图确实是只显示目前活着的事务,这里没有事务,并不等于一个事务没发生过
I see what you mean. To find out what locks have been acquired during a very short period of time (too short for you to check in v$lock), you can use event 10704:
conn username/password
select spid from v$process where addr = (select paddr from v$session where sid in (select sid from v$mystat));
alter session set events '10704 trace name context forever, level 10';
--delete from t where rownum = 1;
delete from t where 1 = 2;
alter session set events '10704 trace name context off';
On my 10.2.0.1 database, I see TM lock taken in mode 3. Apparently it means that even if no row is selected, for a brief period, a mode 3 table lock was taken on that table. But since there's no TX lock, we can safely say no transaction took place. If you change the where to actually delete a row, you *will* see TX in the trace file.
Yong Huang
只看该作者
sqysl
孤独剑客
来自 山东
精华贴数 0
个人空间
0
技术积分 1258 (1379)
社区积分 31 (6182)
注册日期 2006-12-20
论坛徽章:0
#10
使用道具
发表于 2008-5-24 20:13
谢谢yong huang的答复,您说的这些我理解,而且和您有相同的观点,现在关键是有个疑问,
那就是ORACLE在开始一个DML语句时,何时获取一个事务槽
,无非有以下几种情况:
第一
,先不获取事务槽,而是先根据DML对涉及到的数据进行扫描,获取到结果后再获取一个事务槽,然后进行真正的数据操作;关键是这种情况下,如何保证从扫描开始到最后实施真正的修改这段时间里,扫描的数据不被其他事务修改和锁定,TM锁能做到吗?
第二
,在开始一个DML时,首先获取一个事务槽,然后对涉及到的数据进行扫描,当对块扫描时,获取一个块ITL,如果这样,无论该块中有没有数据被修改,该事务本身由于获取了ITL,都形成了对该块修改了的事实,即修改了块头;
第三
,在开始一个DML时,首先获取一个事务槽,然后对涉及到的数据进行扫描,但在扫描过程中,并不获取ITL,直到扫描某个数据块时,发现该块中有需要加锁修改的数据时,再获取一个块ITL,然后加锁、修改,这种情况下,虽然获取了一个事务槽,但并未修改相应的数据块,不知道这情况算不算获取了一个事务锁。
当然,DELETE FROM TEST WHERE 1=2中的条件ORACLE很容易判断没有符合条件的行,但然过我把WHERE条件换成一个现实的条件,比如:
create table test as select * from dba_extents;
delete from test where owner='####';
而test表里没有符合owner='####'条件的数据时,上面的问题是个什么情况呢?个人愚见,希望大家共同讨论,共同进步。
[
本帖最后由 sqysl 于 2008-5-24 20:19 编辑
]
__________________
曾经沧海难为水,除却巫山不是云。
天若有情天亦老,人间正道是沧桑。
只看该作者
26
1/3
1
2
3
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> 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号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计