视窗
loading...
您现在的位置:首页 > IT认证 > oracle认证 >

OracleRAC环境对并行查询的支持


   RAC环境中,一个并行的执行可能分布到多个实例上执行。

  如果连接Oracle RAC数据库时,一个节点上的并发操作可以分布到多个节点上同时执行。

  看一个简单的例子:

  SQL> CONN TEST/TEST@TESTRAC已连接。

  SQL> SELECT INSTANCE_NAME FROM V$INSTANCE;

  INSTANCE_NAME

  ----------------

  testrac2

  SQL > SELECT INSTANCE_NAME FROM GV$INSTANCE;

  INSTANCE_NAME

  ----------------

  testrac1

  testrac2

  SQL > SELECT * FROM V$VERSION;

  BANNER

  ----------------------------------------------------------------

  Oracle Database 10g Enterprise Edition Release 10.2.0.3.0 - 64bi

  PL/SQL Release 10.2.0.3.0 - Production

  CORE 10.2.0.3.0 Production

  TNS for Solaris: Version 10.2.0.3.0 - Production

  NLSRTL Version 10.2.0.3.0 - Production

  这是一个10g的环境,下面建立一张测试表,建立过程中设置表的并行度:

  SQL> CREATE TABLE T_PARALLEL PARALLEL 16

  2 AS SELECT A.* FROM DBA_OBJECTS A, DBA_TABLES

  3 WHERE ROWNUM <= 5000000;

  表已创建。

  SQL> SET AUTOT ON

  SQL> SELECT COUNT(*) FROM T_PARALLEL;

  COUNT(*)

  ----------

  5000000

 执行计划

  ----------------------------------------------------------

  Plan hash value: 70256698

  ----------------------------------------------------------------------------------------------------------

  | Id | Operation | Name | Rows | Cost (%CPU)| Time | TQ |IN-OUT| PQ Distrib |

  ----------------------------------------------------------------------------------------------------------

  | 0 | SELECT STATEMENT | | 1 | 1081 (2)| 00:00:13 | | | |

  | 1 | SORT AGGREGATE | | 1 | | | | | |

  | 2 | PX COORDINATOR | | | | | | | |

  | 3 | PX SEND QC (RANDOM) | :TQ10000 | 1 | | | Q1,00 | P- >S | QC (RAND) |

  | 4 | SORT AGGREGATE | | 1 | | | Q1,00 | PCWP | |

  | 5 | PX BLOCK ITERATOR | | 4588K| 1081 (2)| 00:00:13 | Q1,00 | PCWC | |

  | 6 | TABLE ACCESS FULL| T_PARALLEL | 4588K| 1081 (2)| 00:00:13 | Q1,00 | PCWP | |

  ----------------------------------------------------------------------------------------------------------

  Note

  -----

  - dynamic sampling used for this statement

  从执行计划可以看到,Oracle选则了并行执行。

  新连接一个会话,在执行上面这个并行查询的同时,检查GV$PX_PROCESS视图:

  SQL> SELECT * FROM GV$PX_PROCESS;

  INST_ID SERV STATUS PID SPID SID SERIAL#

  ---------- ---- --------- ---------- ------------ ---------- ----------

  2 P000 IN USE 21 25120 265 13

  2 PZ99 IN USE 42 25480 271 39

  2 P001 IN USE 24 25122 279 1579

  2 P002 IN USE 34 25124 280 602

  2 P003 IN USE 35 25126 281 42

  2 P004 IN USE 37 25155 284 106

  2 P005 IN USE 41 25159 296 2212

  1 P009 IN USE 44 27375 244 20

  1 P004 IN USE 39 27336 246 504

  1 P000 IN USE 24 27328 247 19

  1 P005 IN USE 40 27349 251 363

  1 P002 IN USE 37 27332 254 76

  1 PZ99 IN USE 45 27725 265 28

  1 P008 IN USE 43 27373 266 46

  1 P006 IN USE 41 27369 270 64

  1 P001 IN USE 32 27330 283 1980

  1 P007 IN USE 42 27371 289 86

  1 P003 IN USE 38 27334 311 21707

  已选择18行。

  很显然,并行查询的16个进程已经分布到两个节点上同时执行了。

闂侀潧妫岄崑锟�

闂侀潧妫岄崑锟�

闂侀潧妫欓崝鏇㈠储閵堝洦瀚婚柨婵嗘嫅缁憋綁鏌¢崟顐︻€楅柟铚傚嵆閹囧醇閻斿摜绉柣鐘叉搐閻°劌危閹达箑违闁跨噦鎷�
闂佸搫鐗滈崜娑㈡偟椤栫偞鐒鹃柕濞垮劚閻庤菐閸ワ絽澧插ù鐓庢嚇瀵爼濡烽敂鍓у煃婵炲瓨绮岀花鑲╄姳娴煎瓨鍤傞柡鍐ㄥ€荤粔褰掓煥濞戣櫕瀚�闁诲海鏁搁、濠偯归崱妯诲闁伙絽鏈悾鍗炃庨崶锝呭⒉濞寸厧鎳橀獮瀣箣濠婂嫮鎷ㄩ梺鍛婃⒐缁嬫帡鎯囨导鏉戝唨闁搞儯鍔嶉~鏍庨崶锝呭⒉濞寸厧鎳橀幆鍐礋椤愩垺鐦旀繝銏f硾鐎氬摜妲愰敓锟�闂佺懓鐡ㄩ崹鍐测堪閹寸姳鐒婂┑鐘叉搐濞呫垹霉閿濆棛鐭庨柍褜鍓欓幊鎰枔閹达附鍋嬮柛顐ゅ枑缂嶁偓闂佹垝鐒﹂妵鐐电礊閺冨牆绾ч柛鎰硶缁€锟�闁诲簼绲婚~澶愬垂濠婂嫮顩锋い鎺戝暞缁侇噣寮堕悙鍨珪婵炲牊鍨剁粚閬嶅焺閸愌呯婵犵鈧啿鈧懓锕㈡担鍓插殨闁稿本绻嶉崬鎾煙鐎涙ḿ澧繝鈧担鍦懝闁割煈鍋呯紞鈧梺鐟扮摠閻楃偟鎹㈠顑芥灃闁哄洦鐭换鍡涙煙椤撗冪仴妞ゆ洦鍓熷畷锝嗙節閸愨晩妲梺鑹伴哺濮婂鏌堥幘顔肩闁瑰瓨绮嶇划锕傛煥濞戞ɑ婀版繝鈧幍顔惧崥婵炲棗娴风粣妤冪磼閺傛鍎忕€规挸妫濆畷姘舵偐缂佹ḿ褰戦梺鎸庡喕閹凤拷闁诲海鏁搁幊鎾舵暜椤愶箑绀嗘繛鎴灻弫鍫曟倵绾拋娼愰柛銊︾矋缁傛帡顢楁担绋啃梺瑙勬緲缁绘垿寮鐣岊浄婵せ鍋撻柍褜鍓欓崐鍝ョ礊鐎n喗鍎嶉柛鏇ㄥ帎瑜版帗鐓€妞ゆ帒锕︾粈锟�闂佽壈椴稿濠氭焾閹绢喖妫橀柣鐔稿绾偓闂佹寧绋掑畝鎼佸磻閺嶃劎顩烽柨鐕傛嫹:webmaster@jscj.com闂侀潧妫岄崑鎾绘煟椤厾绁烽柣锔跨矙閺佸秹鏁撻敓锟�4008816886

相关文章

无相关信息
更新时间2022-03-13 10:53:44【至顶部↑】
联系我们 | 邮件: webmaster@jscj.com | 客服热线电话:4008816886(QQ同号) |  濠电儑缍€椤曆勬叏閻愮鍋撻獮鍨仾婵犫偓閸パ屽殫妞ゆ棁顔婄换锟�

付款方式留言簿投诉中心网站纠错二维码手机版

客服电话: