{"id":203,"date":"2015-03-04T16:05:49","date_gmt":"2015-03-04T15:05:49","guid":{"rendered":"http:\/\/explainit.pl\/blog\/?p=203"},"modified":"2016-08-09T20:58:53","modified_gmt":"2016-08-09T18:58:53","slug":"indeksy-czesciowe-w-oracle-database-12c","status":"publish","type":"post","link":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/","title":{"rendered":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c"},"content":{"rendered":"<p>Oracle Database 12c oferuje ciekawe rozwi\u0105zanie, pozwalaj\u0105ce zredukowa\u0107 rozmiar indeksu tworzonego na tabeli partycjonowanej, w kt\u00f3rej wiele partycji ma charakter archiwalny (bardzo rzadko podlega zapytaniom). Indeks cz\u0119\u015bciowy &#8211; bo o nim mowa &#8211; mo\u017ce obejmowa\u0107 swoim zasi\u0119giem wybrane partycje tabeli, podczas gdy rekordy w pozosta\u0142ych partycjach tabeli pozostaj\u0105 bez indeksu. Gdy realizowane jest zapytanie do tak indeksowanej tabeli, optymalizator zapyta\u0144 skorzysta z indeksu w przypadku partycji uwzgl\u0119dnionych w indeksie, oraz z pe\u0142nego odczytu partycji w pozosta\u0142ych przypadkach.<br \/>\nAby utworzy\u0107 indeks cz\u0119\u015bciowy nale\u017cy najpierw na poziomie tabeli wskaza\u0107, kt\u00f3re jej partycje powinny by\u0107 uwzgl\u0119dniane w indeksie, a kt\u00f3re nie (klauzula &#8222;indexing&#8221;):<\/p>\n<p><code>create table faktury (nr varchar2(20), kwota number(8,2), data date)<br \/>\npartition by range (data)<br \/>\n(partition p1 values less than (to_date('01-01-2014','DD-MM-YYYY')) indexing off,<br \/>\npartition p2 values less than (to_date('01-01-2015','DD-MM-YYYY')) indexing off,<br \/>\npartition p3 values less than (to_date('01-01-2016','DD-MM-YYYY')) indexing on);<\/code><\/p>\n<p>a nast\u0119pnie utworzy\u0107 indeks z klauzul\u0105 &#8222;indexing partial&#8221;:<\/p>\n<p><code>create index i1 on faktury(nr) indexing partial;<\/code><\/p>\n<p>A oto przyk\u0142ad planu wykonania zapytania do tabeli posiadaj\u0105cej indeks cz\u0119\u015bciowy.<\/p>\n<p><code>select * from faktury where nr='12345'<\/code><\/p>\n<p><code>------------------------------------------------------------------------------<br \/>\n| Id | Operation\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0\u00a0 | Name\u00a0\u00a0 |Rows|Pstart|Pstop|<br \/>\n------------------------------------------------------------------------------<br \/>\n| 0\u00a0 | SELECT STATEMENT\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 |\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 | 114|\u00a0\u00a0 \u00a0\u00a0 |\u00a0\u00a0\u00a0\u00a0 |<br \/>\n| 1\u00a0 | VIEW\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0\u00a0 | VW_TE_2| \u00a0\u00a0 |\u00a0\u00a0\u00a0\u00a0\u00a0 | \u00a0 \u00a0 |<br \/>\n| 2\u00a0 | UNION-ALL\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 |\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 | \u00a0\u00a0 |\u00a0\u00a0\u00a0\u00a0\u00a0 | \u00a0 \u00a0 |<br \/>\n|* 3 | TABLE ACCESS BY GLOBAL INDEX ROWID BATCHED | FAKTURY| 76 | \u00a0\u00a0 3 | \u00a0 3 |<br \/>\n|* 4 | INDEX RANGE SCAN \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 | I1\u00a0\u00a0\u00a0\u00a0 | 114| \u00a0 \u00a0\u00a0 | \u00a0 \u00a0 |<br \/>\n| 5\u00a0 | PARTITION RANGE ITERATOR\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 | \u00a0 \u00a0 \u00a0\u00a0 | 75 | \u00a0\u00a0 1 |\u00a0\u00a0 2 |<br \/>\n|* 6 | TABLE ACCESS FULL\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 | FAKTURY| 75 |\u00a0 \u00a0 1 |\u00a0\u00a0 2 |<br \/>\n------------------------------------------------------------------------------<\/code><\/p>\n<p>Zapytanie zosta\u0142o podzielone na dwie cz\u0119\u015bci. Przeszukanie partycji nr 3 odby\u0142o si\u0119 z u\u017cyciem indeksu. Partycje nr 1 i nr 2 zosta\u0142y poddane pe\u0142nemu odczytowi.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Oracle Database 12c oferuje ciekawe rozwi\u0105zanie, pozwalaj\u0105ce zredukowa\u0107 rozmiar indeksu tworzonego na tabeli partycjonowanej, w kt\u00f3rej wiele partycji ma charakter archiwalny (bardzo rzadko podlega zapytaniom). Indeks cz\u0119\u015bciowy &#8211; bo o nim mowa &#8211; mo\u017ce obejmowa\u0107 swoim zasi\u0119giem wybrane partycje tabeli, podczas gdy rekordy w pozosta\u0142ych partycjach tabeli pozostaj\u0105 bez indeksu. Gdy realizowane jest zapytanie do <a href=\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\" rel=\"nofollow\"><span class=\"sr-only\">Read more about Indeksy cz\u0119\u015bciowe w Oracle Database 12c<\/span>[&hellip;]<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[2],"tags":[10,14],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.2.1 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Indeksy cz\u0119\u015bciowe w Oracle Database 12c - Explain IT<\/title>\n<meta name=\"description\" content=\"Indeksy cz\u0119\u015bciowe w Oracle Database 12c\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\" \/>\n<meta property=\"og:locale\" content=\"pl_PL\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Indeksy cz\u0119\u015bciowe w Oracle Database 12c - Explain IT\" \/>\n<meta property=\"og:description\" content=\"Indeksy cz\u0119\u015bciowe w Oracle Database 12c\" \/>\n<meta property=\"og:url\" content=\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\" \/>\n<meta property=\"og:site_name\" content=\"Explain IT\" \/>\n<meta property=\"article:published_time\" content=\"2015-03-04T15:05:49+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2016-08-09T18:58:53+00:00\" \/>\n<meta name=\"author\" content=\"Maciej Zakrzewicz\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Napisane przez\" \/>\n\t<meta name=\"twitter:data1\" content=\"Maciej Zakrzewicz\" \/>\n\t<meta name=\"twitter:label2\" content=\"Szacowany czas czytania\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 minuta\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\"},\"author\":{\"name\":\"Maciej Zakrzewicz\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/#\/schema\/person\/740773131bc169a2dc9c0e5e07476219\"},\"headline\":\"Indeksy cz\u0119\u015bciowe w Oracle Database 12c\",\"datePublished\":\"2015-03-04T15:05:49+00:00\",\"dateModified\":\"2016-08-09T18:58:53+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\"},\"wordCount\":173,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/explainit.pl\/wordpress\/#organization\"},\"keywords\":[\"indeksy\",\"Oracle Database 12c\"],\"articleSection\":[\"Oracle Database\"],\"inLanguage\":\"pl-PL\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\",\"url\":\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\",\"name\":\"Indeksy cz\u0119\u015bciowe w Oracle Database 12c - Explain IT\",\"isPartOf\":{\"@id\":\"https:\/\/explainit.pl\/wordpress\/#website\"},\"datePublished\":\"2015-03-04T15:05:49+00:00\",\"dateModified\":\"2016-08-09T18:58:53+00:00\",\"description\":\"Indeksy cz\u0119\u015bciowe w Oracle Database 12c\",\"breadcrumb\":{\"@id\":\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#breadcrumb\"},\"inLanguage\":\"pl-PL\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Strona g\u0142\u00f3wna\",\"item\":\"https:\/\/explainit.pl\/wordpress\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Indeksy cz\u0119\u015bciowe w Oracle Database 12c\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/#website\",\"url\":\"https:\/\/explainit.pl\/wordpress\/\",\"name\":\"Explain IT\",\"description\":\"Autorska pracownia doradztwa i szkole\u0144 IT - Maciej Zakrzewicz - szkolenia, ekspertyzy, wdro\u017cenia. Technologie Oracle, PostgreSQL, MySQL.\",\"publisher\":{\"@id\":\"https:\/\/explainit.pl\/wordpress\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/explainit.pl\/wordpress\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"pl-PL\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/#organization\",\"name\":\"Explain IT\",\"url\":\"https:\/\/explainit.pl\/wordpress\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pl-PL\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/explainit.pl\/wordpress\/wp-content\/uploads\/2016\/08\/explainITmini.png\",\"contentUrl\":\"https:\/\/explainit.pl\/wordpress\/wp-content\/uploads\/2016\/08\/explainITmini.png\",\"width\":196,\"height\":64,\"caption\":\"Explain IT\"},\"image\":{\"@id\":\"https:\/\/explainit.pl\/wordpress\/#\/schema\/logo\/image\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/#\/schema\/person\/740773131bc169a2dc9c0e5e07476219\",\"name\":\"Maciej Zakrzewicz\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pl-PL\",\"@id\":\"https:\/\/explainit.pl\/wordpress\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/9c98d020128b142a480aa35a22300a69?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/9c98d020128b142a480aa35a22300a69?s=96&d=mm&r=g\",\"caption\":\"Maciej Zakrzewicz\"}}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c - Explain IT","description":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/","og_locale":"pl_PL","og_type":"article","og_title":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c - Explain IT","og_description":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c","og_url":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/","og_site_name":"Explain IT","article_published_time":"2015-03-04T15:05:49+00:00","article_modified_time":"2016-08-09T18:58:53+00:00","author":"Maciej Zakrzewicz","twitter_card":"summary_large_image","twitter_misc":{"Napisane przez":"Maciej Zakrzewicz","Szacowany czas czytania":"1 minuta"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#article","isPartOf":{"@id":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/"},"author":{"name":"Maciej Zakrzewicz","@id":"https:\/\/explainit.pl\/wordpress\/#\/schema\/person\/740773131bc169a2dc9c0e5e07476219"},"headline":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c","datePublished":"2015-03-04T15:05:49+00:00","dateModified":"2016-08-09T18:58:53+00:00","mainEntityOfPage":{"@id":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/"},"wordCount":173,"commentCount":0,"publisher":{"@id":"https:\/\/explainit.pl\/wordpress\/#organization"},"keywords":["indeksy","Oracle Database 12c"],"articleSection":["Oracle Database"],"inLanguage":"pl-PL","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/","url":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/","name":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c - Explain IT","isPartOf":{"@id":"https:\/\/explainit.pl\/wordpress\/#website"},"datePublished":"2015-03-04T15:05:49+00:00","dateModified":"2016-08-09T18:58:53+00:00","description":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c","breadcrumb":{"@id":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#breadcrumb"},"inLanguage":"pl-PL","potentialAction":[{"@type":"ReadAction","target":["https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/explainit.pl\/wordpress\/2015\/03\/04\/indeksy-czesciowe-w-oracle-database-12c\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Strona g\u0142\u00f3wna","item":"https:\/\/explainit.pl\/wordpress\/"},{"@type":"ListItem","position":2,"name":"Indeksy cz\u0119\u015bciowe w Oracle Database 12c"}]},{"@type":"WebSite","@id":"https:\/\/explainit.pl\/wordpress\/#website","url":"https:\/\/explainit.pl\/wordpress\/","name":"Explain IT","description":"Autorska pracownia doradztwa i szkole\u0144 IT - Maciej Zakrzewicz - szkolenia, ekspertyzy, wdro\u017cenia. Technologie Oracle, PostgreSQL, MySQL.","publisher":{"@id":"https:\/\/explainit.pl\/wordpress\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/explainit.pl\/wordpress\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"pl-PL"},{"@type":"Organization","@id":"https:\/\/explainit.pl\/wordpress\/#organization","name":"Explain IT","url":"https:\/\/explainit.pl\/wordpress\/","logo":{"@type":"ImageObject","inLanguage":"pl-PL","@id":"https:\/\/explainit.pl\/wordpress\/#\/schema\/logo\/image\/","url":"https:\/\/explainit.pl\/wordpress\/wp-content\/uploads\/2016\/08\/explainITmini.png","contentUrl":"https:\/\/explainit.pl\/wordpress\/wp-content\/uploads\/2016\/08\/explainITmini.png","width":196,"height":64,"caption":"Explain IT"},"image":{"@id":"https:\/\/explainit.pl\/wordpress\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/explainit.pl\/wordpress\/#\/schema\/person\/740773131bc169a2dc9c0e5e07476219","name":"Maciej Zakrzewicz","image":{"@type":"ImageObject","inLanguage":"pl-PL","@id":"https:\/\/explainit.pl\/wordpress\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/9c98d020128b142a480aa35a22300a69?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/9c98d020128b142a480aa35a22300a69?s=96&d=mm&r=g","caption":"Maciej Zakrzewicz"}}]}},"_links":{"self":[{"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/posts\/203"}],"collection":[{"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/comments?post=203"}],"version-history":[{"count":1,"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/posts\/203\/revisions"}],"predecessor-version":[{"id":335,"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/posts\/203\/revisions\/335"}],"wp:attachment":[{"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/media?parent=203"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/categories?post=203"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/explainit.pl\/wordpress\/wp-json\/wp\/v2\/tags?post=203"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}