mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Add an in-core GiST index opclass for inet/cidr types.
This operator class can accelerate subnet/supernet tests as well as btree-equivalent ordered comparisons. It also handles a new network operator inet && inet (overlaps, a/k/a "is supernet or subnet of"), which is expected to be useful in exclusion constraints. Ideally this opclass would be the default for GiST with inet/cidr data, but we can't mark it that way until we figure out how to do a more or less graceful transition from the current situation, in which the really-completely-bogus inet/cidr opclasses in contrib/btree_gist are marked as default. Having the opclass in core and not default is better than not having it at all, though. While at it, add new documentation sections to allow us to officially document GiST/GIN/SP-GiST opclasses, something there was never a clear place to do before. I filled these in with some simple tables listing the existing opclasses and the operators they support, but there's certainly scope to put more information there. Emre Hasegeli, reviewed by Andreas Karlsson, further hacking by me
This commit is contained in:
		| @@ -53,6 +53,93 @@ | ||||
|  | ||||
| </sect1> | ||||
|  | ||||
| <sect1 id="spgist-builtin-opclasses"> | ||||
|  <title>Built-in Operator Classes</title> | ||||
|  | ||||
|  <para> | ||||
|   The core <productname>PostgreSQL</> distribution | ||||
|   includes the <acronym>SP-GiST</acronym> operator classes shown in | ||||
|   <xref linkend="spgist-builtin-opclasses-table">. | ||||
|  </para> | ||||
|  | ||||
|   <table id="spgist-builtin-opclasses-table"> | ||||
|    <title>Built-in <acronym>SP-GiST</acronym> Operator Classes</title> | ||||
|    <tgroup cols="3"> | ||||
|     <thead> | ||||
|      <row> | ||||
|       <entry>Name</entry> | ||||
|       <entry>Indexed Data Type</entry> | ||||
|       <entry>Indexable Operators</entry> | ||||
|      </row> | ||||
|     </thead> | ||||
|     <tbody> | ||||
|      <row> | ||||
|       <entry><literal>kd_point_ops</></entry> | ||||
|       <entry><type>point</></entry> | ||||
|       <entry> | ||||
|        <literal><<</> | ||||
|        <literal><@</> | ||||
|        <literal><^</> | ||||
|        <literal>>></> | ||||
|        <literal>>^</> | ||||
|        <literal>~=</> | ||||
|       </entry> | ||||
|      </row> | ||||
|      <row> | ||||
|       <entry><literal>quad_point_ops</></entry> | ||||
|       <entry><type>point</></entry> | ||||
|       <entry> | ||||
|        <literal><<</> | ||||
|        <literal><@</> | ||||
|        <literal><^</> | ||||
|        <literal>>></> | ||||
|        <literal>>^</> | ||||
|        <literal>~=</> | ||||
|       </entry> | ||||
|      </row> | ||||
|      <row> | ||||
|       <entry><literal>range_ops</></entry> | ||||
|       <entry>any range type</entry> | ||||
|       <entry> | ||||
|        <literal>&&</> | ||||
|        <literal>&<</> | ||||
|        <literal>&></> | ||||
|        <literal>-|-</> | ||||
|        <literal><<</> | ||||
|        <literal><@</> | ||||
|        <literal>=</> | ||||
|        <literal>>></> | ||||
|        <literal>@></> | ||||
|       </entry> | ||||
|      </row> | ||||
|      <row> | ||||
|       <entry><literal>text_ops</></entry> | ||||
|       <entry><type>text</></entry> | ||||
|       <entry> | ||||
|        <literal><</> | ||||
|        <literal><=</> | ||||
|        <literal>=</> | ||||
|        <literal>></> | ||||
|        <literal>>=</> | ||||
|        <literal>~<=~</> | ||||
|        <literal>~<~</> | ||||
|        <literal>~>=~</> | ||||
|        <literal>~>~</> | ||||
|       </entry> | ||||
|      </row> | ||||
|     </tbody> | ||||
|    </tgroup> | ||||
|   </table> | ||||
|  | ||||
|  <para> | ||||
|   Of the two operator classes for type <type>point</>, | ||||
|   <literal>quad_point_ops</> is the default.  <literal>kd_point_ops</> | ||||
|   supports the same operators but uses a different index data structure which | ||||
|   may offer better performance in some applications. | ||||
|  </para> | ||||
|  | ||||
| </sect1> | ||||
|  | ||||
| <sect1 id="spgist-extensibility"> | ||||
|  <title>Extensibility</title> | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user