- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
JAVA中锁概念及运用.doc
一、锁的概念及分类 ORACLE数据库是现今数据库领域应用最广泛的,同时它也是一个庞大的系统,全面了解它、玩转它不但需要一定的理论知识,更需要开发经验与工程经验。本人是ORACLE一爱好者,以下是本人对ORACLE锁的一些经验,希望能与大家共同分享。 ORACLE锁具体分为以下几类: 1.按用户与系统划分,可以分为自动锁与显示锁 自动锁:当进行一项数据库操作时,缺省情况下,系统自动为此数据库操作获得所有有必要的锁。 显示锁:某些情况下,需要用户显示的锁定数据库操作要用到的数据,才能使数据库操作执行得更好,显示锁是用户为数据库对象设定的。 2.按锁级别划分,可分为共享锁、共享更新锁、排它锁 共享锁:共享锁使一个事务对特定数据库资源进行共享访问——另一事务也可对此资源进行访问或获得相同共享锁。共享锁为事务提供高并发性,但如拙劣的事务设计+共享锁容易造成死锁或数据更新丢失。 ????? ―锁定表 ?????? ―仅允许其他用户执行查询操作 ?????? ―不能插入、更新和删除 ?????? ―多个用户可以同时在同一表中放置此锁 ??????? ―lock table table_name ?????? ―in share mode [nowait]; ?????? ― rollback 和commit 命令释放锁 ????? ― nowait 关键字告诉其他用户不用等 ?? 共享更新锁 ??????????? ―锁定要被更新的行 ?????????? ―允许其他用户同时查询、插入、更新未被锁定的行 ???????????? ―在 SELECT 语句中使用“FOR UPDATE”子句,可以强制使用共享更新锁 ??????????? ―允许多个用户同时锁定表的不同行 ?????????? 加锁的两种方法 ????????? 1 lock table tab_name in share update mode; ????????? 2 select column1,column2 ????????? from goods ???????? where goods ????????? where gid=1001 ???????? for update of column1,column2 排它锁:事务设置排它锁后,该事务单独获得此资源,另一事务不能在此事务提交之前获得相同对象的共享锁或排它锁。 ????????? ―与其他两种锁相比,排他锁是限制性最强的表锁 ????????? ―仅允许其他用户查询数据 ????????? ―不允许执行插入、删除和更新操作 ????????? ―在同一时间仅允许一位用户在表上放置排他锁 ????????? ―共享锁与此相反 ????????? lock table tab_name in exclusive mode; ????????? lock table表名[表名]... ????????? in share mode [nowait] ????????? lock table 表名[表名]... ????????? in exclusive mode [nowait] ???????? lock table表名[表名]... ???????? in share update mode[nowait] 3.按操作划分,可分为DML锁、DDL锁 +DML锁又可以分为,行锁、表锁、死锁 -行锁:当事务执行数据库插入、更新、删除操作时,该事务自动获得操作表中操作行的排它锁。 ????????????? 手动锁定方式:SELECT…FOR UPDATE 子句 ?????????????????????? ―在表的一行或多行上放置排他锁 ?????????????????????? ―用于防止其他用户更新该行 ??????????????????????? ―可以执行除更新之外的其他操作 ????????????????????? ―select * from goods where gid=1001 ????????????????????? ―for update of gname; ??????????????????? ―只有该用户提交事务,其他用户才能够更新gname ???????????????????? FOR UPDATE WAIT 子句 ??????????????????? ―Oracle9i 中的新增功能 ?????????????????? ―防止无限期地等待锁定的行 ??????????????????
您可能关注的文档
最近下载
- 2025内蒙古自治区人大常委会办公厅所属事业单位竞争性比选工作人员17人考试备考题库及答案解析.docx VIP
- 专题4++中华民族的伟大复兴——屈辱史、探索史、党的发展史、复兴史+课件+2025年云南省中考历史备考二轮复习.pptx VIP
- 米家掌航智能门锁H6使用说明书.pdf
- 钢帘线生产工艺.pdf
- 2025内蒙古自治区人大常委会办公厅所属事业单位竞争性比选工作人员17人笔试备考试题及答案解析.docx VIP
- 天龙AVR-1312功放说明书.pdf
- [软件测试]-软件测试说明书的模板.docx VIP
- 2023-2024初中物理竞赛试题精选精编第01讲力、重力、弹力(含解析).doc VIP
- 刍议QC/T+29106-2014汽车电线束技术条件.pdf VIP
- 2025内蒙古自治区人大常委会办公厅所属事业单位竞争性比选工作人员17人笔试模拟试题及答案解析.docx VIP
文档评论(0)