- 1、本文档共30页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oracle SQL 培训讲义 Michale Zeng SQL中常见的误区和隐患 单条SQL实现常见的特殊需求 SQL实现OLAP的报表功能 谁动了我的INDEX 为什么有索引但是没起作用? 代码疏忽,例如包含格式的隐式转换 表大小低于“小表”的阀值(内部定义,默认大小是Buffer的20%) 索引具有较低的可选性 特殊的索引 FBI Function Based Index SQL desc t_fbi Name Type Nullable Default Comments ---- -------------- -------- ------- -------- RN NUMBER Y NAME VARCHAR2(4000) Y DT DATE Y CREATE INDEX idx_nonfbi ON t_fbi(dt); 为什么下面的SQL不能使用索引idx_nonfbi? SELECT * FROM t_fbi WHERE trunc(dt) = to_date(2006-09-21,yyyy-mm-dd) ; SELECT * FROM t_fbi WHERE to_char(dt, yyyy-mm-dd) = 2006-09-21; CREATE INDEX idx_fbi_1 ON t_fbi(trunc(dt)); LOOP过程中的COMMIT Oracle中,commit引起Redo Log的物理I/O 为提高效率,尽可能的批量提交 -- 逐行提交DECLAREBEGIN FOR cur IN (SELECT * FROM user_objects) LOOP INSERT INTO t_loop VALUES cur; COMMIT; END LOOP;END; -- 模拟批量提交DECLARE v_count NUMBER;BEGIN FOR cur IN (SELECT * FROM user_objects) LOOP INSERT INTO t_loop VALUES cur; v_count := v_count + 1; IF v_count = 100 THEN COMMIT; END IF; END LOOP; COMMIT;END; LOOP过程中的COMMIT -- 真正的批量提交,用到嵌套表(数组)的特性 DECLARE CURSOR cur IS SELECT * FROM user_objects; TYPE rec IS TABLE OF user_objects%ROWTYPE; recs rec;BEGIN OPEN cur; WHILE (TRUE) LOOP FETCH cur BULK COLLECT INTO recs LIMIT 100; -- forall 实现批量 FORALL i IN 1 .. recs.COUNT INSERT INTO t_loop VALUES recs (i); COMMIT; EXIT WHEN cur%NOTFOUND; END LOOP; CLOSE cur;END; 悲观锁定/乐观锁定 业务需求:在插入纪录的同时,生成连续的流水号 -- 常见的实现逻辑,隐含bugDECLARE v_cnt NUMBER;BEGIN -- 这里会有什么样的BUG? SELECT MAX(ID) INTO v_cnt FROM t_lock; -- here for other operation v_cnt := v_cnt + 1; INSERT INTO t_lock (ID) VALUES (v_cnt); COMMIT;END; 悲观锁定/乐观锁定 -- 高并发环境下,安全的实现逻辑DECLARE v_cnt NUMBER;BEGIN -- 对指定的行取得lock SELECT ID INTO v_cnt FROM t_lock WHERE ID=1 FOR UPDATE; -- 在有lock的情况下继续下面的操作 SELECT MAX(ID) INTO v_cnt FROM t_lock; -- here for other operation v_cnt := v_cnt +
您可能关注的文档
- 江苏事业单位典型题摘要.doc
- ICU患者血糖监测与处理.摘要.ppt
- ICU血糖控制摘要.ppt
- ICU中血液净化的应用指南摘要.ppt
- IC应用(综合)摘要.ppt
- IE七大手法之防错法摘要.ppt
- 江西省国家编制考试教育综合基础知识重点全面摘要.doc
- 江西省吉安市高一下学期期末教学质量评价生物试卷摘要.doc
- 江西省临川一中2012届高三生物期中考试试卷摘要.doc
- IgG4相关性肺病摘要.ppt
- 四川省德阳市罗江中学2025届高三考前热身化学试卷含解析.doc
- 山东省枣庄现代实验学校2025届高三下学期第五次调研考试化学试题含解析.doc
- 吉林省长春市十一高中等九校教育联盟2025届高三一诊考试生物试卷含解析.doc
- 2025届江苏省盐城市伍佑中学高考仿真模拟化学试卷含解析.doc
- 2025届广西贺州中学高考冲刺押题(最后一卷)生物试卷含解析.doc
- 安徽省池州市贵池区2025届高三第一次模拟考试生物试卷含解析.doc
- 宁夏银川一中2025届高三(最后冲刺)化学试卷含解析.doc
- 广东省广州市增城区四校联考2025届高考压轴卷化学试卷含解析.doc
- 2025届邯郸市第一中学高考生物必刷试卷含解析.doc
- 2025届安徽省安庆市石化第一中学高考仿真卷化学试卷含解析.doc
文档评论(0)