mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 00:03:18 -04:00 
			
		
		
		
	doc: Fix spacing in verbatim environments
This commit is contained in:
		
							parent
							
								
									6048896e4c
								
							
						
					
					
						commit
						53166fe248
					
				| @ -238,9 +238,9 @@ include 'filename' | ||||
|         The <filename>postgresql.conf</> file can also contain | ||||
|         <literal>include_dir</literal> directives, which specify an entire directory | ||||
|         of configuration files to include.  It is used similarly: | ||||
|  <programlisting> | ||||
|  include_dir 'directory' | ||||
|  </programlisting> | ||||
| <programlisting> | ||||
| include_dir 'directory' | ||||
| </programlisting> | ||||
|         Non-absolute directory names follow the same rules as single file include | ||||
|         directives:  they are relative to the directory containing the referencing | ||||
|         configuration file.  Within that directory, only non-directory files whose | ||||
| @ -263,11 +263,11 @@ include 'filename' | ||||
|        situation is to break the custom configuration changes for your site into | ||||
|        three files.  You could add this to the end of your | ||||
|        <filename>postgresql.conf</> file to include them: | ||||
|  <programlisting> | ||||
|  include 'shared.conf' | ||||
|  include 'memory.conf' | ||||
|  include 'server.conf' | ||||
|  </programlisting> | ||||
| <programlisting> | ||||
| include 'shared.conf' | ||||
| include 'memory.conf' | ||||
| include 'server.conf' | ||||
| </programlisting> | ||||
|        All systems would have the same <filename>shared.conf</>.  Each server | ||||
|        with a particular amount of memory could share the same | ||||
|        <filename>memory.conf</>; you might have one for all servers with 8GB of RAM, | ||||
| @ -279,15 +279,15 @@ include 'filename' | ||||
|        Another possibility is to create a configuration file directory and | ||||
|        put this information into files there. For example, a <filename>conf.d</> | ||||
|        directory could be referenced at the end of<filename>postgresql.conf</>: | ||||
|  <screen> | ||||
|  include_dir 'conf.d' | ||||
|  </screen> | ||||
| <programlisting> | ||||
| include_dir 'conf.d' | ||||
| </programlisting> | ||||
|        Then you could name the files in the <filename>conf.d</> directory like this: | ||||
|  <screen> | ||||
|  00shared.conf | ||||
|  01memory.conf | ||||
|  02server.conf | ||||
|  </screen> | ||||
| <programlisting> | ||||
| 00shared.conf | ||||
| 01memory.conf | ||||
| 02server.conf | ||||
| </programlisting> | ||||
|        This shows a clear order in which these files will be loaded.  This is | ||||
|        important because only the last setting encountered when the server is | ||||
|        reading its configuration will be used.  Something set in | ||||
| @ -298,11 +298,11 @@ include 'filename' | ||||
|      <para> | ||||
|        You might instead use this configuration directory approach while naming | ||||
|        these files more descriptively: | ||||
|  <screen> | ||||
|  00shared.conf | ||||
|  01memory-8GB.conf | ||||
|  02server-foo.conf | ||||
|  </screen> | ||||
| <programlisting> | ||||
| 00shared.conf | ||||
| 01memory-8GB.conf | ||||
| 02server-foo.conf | ||||
| </programlisting> | ||||
|        This sort of arrangement gives a unique name for each configuration file | ||||
|        variation.  This can help eliminate ambiguity when several servers have | ||||
|        their configurations all stored in one place, such as in a version | ||||
|  | ||||
| @ -1167,12 +1167,12 @@ include $(PGXS) | ||||
|     This procedure is also called a | ||||
|     <indexterm><primary>VPATH</primary></indexterm><firstterm>VPATH</firstterm> | ||||
|     build.  Here's how: | ||||
|     <screen> | ||||
|       <userinput>mkdir build_dir</userinput> | ||||
|       <userinput>cd build_dir</userinput> | ||||
|       <userinput>make -f /path/to/extension/source/tree/Makefile</userinput> | ||||
|       <userinput>make -f /path/to/extension/source/tree/Makefile install</userinput> | ||||
|     </screen> | ||||
| <programlisting> | ||||
| mkdir build_dir | ||||
| cd build_dir | ||||
| make -f /path/to/extension/source/tree/Makefile | ||||
| make -f /path/to/extension/source/tree/Makefile install | ||||
| </programlisting> | ||||
|    </para> | ||||
| 
 | ||||
|    <para> | ||||
| @ -1181,10 +1181,10 @@ include $(PGXS) | ||||
|     core script <filename>config/prep_buildtree</>. Once this has been done | ||||
|     you can build by setting the <literal>make</literal> variable | ||||
|     <varname>USE_VPATH</varname> like this: | ||||
|     <screen> | ||||
|       <userinput>make USE_VPATH=/path/to/extension/source/tree</userinput> | ||||
|       <userinput>make USE_VPATH=/path/to/extension/source/tree install</userinput> | ||||
|     </screen> | ||||
| <programlisting> | ||||
| make USE_VPATH=/path/to/extension/source/tree | ||||
| make USE_VPATH=/path/to/extension/source/tree install | ||||
| </programlisting> | ||||
|     This procedure can work with a greater variety of directory layouts. | ||||
|    </para> | ||||
| 
 | ||||
|  | ||||
| @ -10495,7 +10495,7 @@ table2-mapping | ||||
| -----+------- | ||||
|  a   | "foo" | ||||
|  b   | "bar" | ||||
|  </programlisting> | ||||
| </programlisting> | ||||
|        </entry> | ||||
|       </row> | ||||
|       <row> | ||||
| @ -10514,7 +10514,7 @@ table2-mapping | ||||
| -----+------- | ||||
|  a   | foo | ||||
|  b   | bar | ||||
|  </programlisting> | ||||
| </programlisting> | ||||
|        </entry> | ||||
|       </row> | ||||
|       <row> | ||||
| @ -10598,7 +10598,7 @@ table2-mapping | ||||
| ---+--- | ||||
|  1 | 2 | ||||
|  3 | 4 | ||||
|  </programlisting> | ||||
| </programlisting> | ||||
|        </entry> | ||||
|       </row> | ||||
|       <row> | ||||
| @ -10671,7 +10671,7 @@ table2-mapping | ||||
|  a |    b    | d  | ||||
| ---+---------+--- | ||||
|  1 | [1,2,3] |  | ||||
|  </programlisting> | ||||
| </programlisting> | ||||
|        </entry> | ||||
|       </row> | ||||
|       <row> | ||||
| @ -10692,7 +10692,7 @@ table2-mapping | ||||
| ---+----- | ||||
|  1 | foo | ||||
|  2 | | ||||
|  </programlisting> | ||||
| </programlisting> | ||||
|        </entry> | ||||
|       </row> | ||||
|      </tbody> | ||||
|  | ||||
| @ -163,7 +163,7 @@ | ||||
|   </para> | ||||
|   <para> | ||||
|    The following are all valid <type>json</> (or <type>jsonb</>) expressions: | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| -- Simple scalar/primitive value | ||||
| -- Primitive values can be numbers, quoted strings, true, false, or null | ||||
| SELECT '5'::json; | ||||
| @ -177,7 +177,7 @@ SELECT '{"bar": "baz", "balance": 7.77, "active": false}'::json; | ||||
| 
 | ||||
| -- Arrays and objects can be nested arbitrarily | ||||
| SELECT '{"foo": [true, "bar"], "tags": {"a": 1, "b": null}}'::json; | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
|   </para> | ||||
| 
 | ||||
|   <para> | ||||
| @ -262,7 +262,7 @@ SELECT '{"reading": 1.230e-5}'::json, '{"reading": 1.230e-5}'::jsonb; | ||||
|     one <type>jsonb</> document has contained within it another one. | ||||
|     These examples return true except as noted: | ||||
|   </para> | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| -- Simple scalar/primitive values contain only the identical value: | ||||
| SELECT '"foo"'::jsonb @> '"foo"'::jsonb; | ||||
| 
 | ||||
| @ -282,7 +282,7 @@ SELECT '[1, 2, [1, 3]]'::jsonb @> '[[1, 3]]'::jsonb; | ||||
| 
 | ||||
| -- Similarly, containment is not reported here: | ||||
| SELECT '{"foo": {"bar": "baz"}}'::jsonb @> '{"bar": "baz"}'::jsonb;  -- yields false | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
| 
 | ||||
|   <para> | ||||
|    The general principle is that the contained object must match the | ||||
| @ -296,13 +296,13 @@ SELECT '{"foo": {"bar": "baz"}}'::jsonb @> '{"bar": "baz"}'::jsonb;  -- yields f | ||||
|    As a special exception to the general principle that the structures | ||||
|    must match, an array may contain a primitive value: | ||||
|   </para> | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| -- This array contains the primitive string value: | ||||
| SELECT '["foo", "bar"]'::jsonb @> '"bar"'::jsonb; | ||||
| 
 | ||||
| -- This exception is not reciprocal -- non-containment is reported here: | ||||
| SELECT '"bar"'::jsonb @> '["bar"]'::jsonb;  -- yields false | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
| 
 | ||||
|   <para> | ||||
|     <type>jsonb</> also has an <firstterm>existence</> operator, which is | ||||
| @ -363,22 +363,22 @@ SELECT '"foo"'::jsonb ? 'foo'; | ||||
|     (For details of the semantics that these operators | ||||
|     implement, see <xref linkend="functions-jsonb-op-table">.) | ||||
|     An example of creating an index with this operator class is: | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| CREATE INDEX idxgin ON api USING gin (jdoc); | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
|     The non-default GIN operator class <literal>jsonb_path_ops</> | ||||
|     supports indexing the <literal>@></> operator only. | ||||
|     An example of creating an index with this operator class is: | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| CREATE INDEX idxginp ON api USING gin (jdoc jsonb_path_ops); | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
|   </para> | ||||
| 
 | ||||
|   <para> | ||||
|     Consider the example of a table that stores JSON documents | ||||
|     retrieved from a third-party web service, with a documented schema | ||||
|     definition.  A typical document is: | ||||
|     <programlisting> | ||||
| <programlisting> | ||||
| { | ||||
|     "guid": "9c36adc1-7fb5-4d5b-83b4-90356a46061a", | ||||
|     "name": "Angela Barton", | ||||
| @ -394,32 +394,32 @@ CREATE INDEX idxginp ON api USING gin (jdoc jsonb_path_ops); | ||||
|         "qui" | ||||
|     ] | ||||
| } | ||||
|     </programlisting> | ||||
| </programlisting> | ||||
|     We store these documents in a table named <structname>api</>, | ||||
|     in a <type>jsonb</> column named <structfield>jdoc</>. | ||||
|     If a GIN index is created on this column, | ||||
|     queries like the following can make use of the index: | ||||
|     <programlisting> | ||||
| <programlisting> | ||||
| -- Find documents in which the key "company" has value "Magnafone" | ||||
| SELECT jdoc->'guid', jdoc->'name' FROM api WHERE jdoc @> '{"company": "Magnafone"}'; | ||||
|     </programlisting> | ||||
| </programlisting> | ||||
|     However, the index could not be used for queries like the | ||||
|     following, because though the operator <literal>?</> is indexable, | ||||
|     it is not applied directly to the indexed column <structfield>jdoc</>: | ||||
|     <programlisting> | ||||
| <programlisting> | ||||
| -- Find documents in which the key "tags" contains key or array element "qui" | ||||
| SELECT jdoc->'guid', jdoc->'name' FROM api WHERE jdoc -> 'tags' ? 'qui'; | ||||
|     </programlisting> | ||||
| </programlisting> | ||||
|     Still, with appropriate use of expression indexes, the above | ||||
|     query can use an index.  If querying for particular items within | ||||
|     the <literal>"tags"</> key is common, defining an index like this | ||||
|     may be worthwhile: | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| -- Note that the "jsonb -> text" operator can only be called on a JSON | ||||
| -- object, so as a consequence of creating this index the root of each | ||||
| -- "jdoc" value must be an object.  This is enforced during insertion. | ||||
| CREATE INDEX idxgintags ON api USING gin ((jdoc -> 'tags')); | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
|     Now, the <literal>WHERE</> clause <literal>jdoc -> 'tags' ? 'qui'</> | ||||
|     will be recognized as an application of the indexable | ||||
|     operator <literal>?</> to the indexed | ||||
| @ -429,10 +429,10 @@ CREATE INDEX idxgintags ON api USING gin ((jdoc -> 'tags')); | ||||
|   </para> | ||||
|   <para> | ||||
|     Another approach to querying is to exploit containment, for example: | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| -- Find documents in which the key "tags" contains array element "qui" | ||||
| SELECT jdoc->'guid', jdoc->'name' FROM api WHERE jdoc @> '{"tags": ["qui"]}'; | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
|     A simple GIN index on the <structfield>jdoc</> column can support this | ||||
|     query.  But note that such an index will store copies of every key and | ||||
|     value in the <structfield>jdoc</> column, whereas the expression index | ||||
| @ -501,17 +501,17 @@ SELECT jdoc->'guid', jdoc->'name' FROM api WHERE jdoc @> '{"tags": ["qu | ||||
|     equality of complete JSON documents. | ||||
|     The <literal>btree</> ordering for <type>jsonb</> datums is seldom | ||||
|     of great interest, but for completeness it is: | ||||
|     <synopsis> | ||||
|       <replaceable>Object</replaceable> > <replaceable>Array</replaceable> > <replaceable>Boolean</replaceable> > <replaceable>Number</replaceable> > <replaceable>String</replaceable> > <replaceable>Null</replaceable> | ||||
| <synopsis> | ||||
| <replaceable>Object</replaceable> > <replaceable>Array</replaceable> > <replaceable>Boolean</replaceable> > <replaceable>Number</replaceable> > <replaceable>String</replaceable> > <replaceable>Null</replaceable> | ||||
| 
 | ||||
|       <replaceable>Object with n pairs</replaceable> > <replaceable>object with n - 1 pairs</replaceable> | ||||
| <replaceable>Object with n pairs</replaceable> > <replaceable>object with n - 1 pairs</replaceable> | ||||
| 
 | ||||
|       <replaceable>Array with n elements</replaceable> > <replaceable>array with n - 1 elements</replaceable> | ||||
|     </synopsis> | ||||
| <replaceable>Array with n elements</replaceable> > <replaceable>array with n - 1 elements</replaceable> | ||||
| </synopsis> | ||||
|       Objects with equal numbers of pairs are compared in the order: | ||||
|     <synopsis> | ||||
|       <replaceable>key-1</replaceable>, <replaceable>value-1</replaceable>, <replaceable>key-2</replaceable> ... | ||||
|     </synopsis> | ||||
| <synopsis> | ||||
| <replaceable>key-1</replaceable>, <replaceable>value-1</replaceable>, <replaceable>key-2</replaceable> ... | ||||
| </synopsis> | ||||
|       Note that object keys are compared in their storage order; | ||||
|       in particular, since shorter keys are stored before longer keys, this | ||||
|       can lead to results that might be unintuitive, such as: | ||||
| @ -520,9 +520,9 @@ SELECT jdoc->'guid', jdoc->'name' FROM api WHERE jdoc @> '{"tags": ["qu | ||||
| </programlisting> | ||||
|       Similarly, arrays with equal numbers of elements are compared in the | ||||
|       order: | ||||
|     <synopsis> | ||||
|       <replaceable>element-1</replaceable>, <replaceable>element-2</replaceable> ... | ||||
|     </synopsis> | ||||
| <synopsis> | ||||
| <replaceable>element-1</replaceable>, <replaceable>element-2</replaceable> ... | ||||
| </synopsis> | ||||
|       Primitive JSON values are compared using the same | ||||
|       comparison rules as for the underlying | ||||
|       <productname>PostgreSQL</productname> data type.  Strings are | ||||
|  | ||||
| @ -51,7 +51,7 @@ | ||||
|     Then, you should connect to the target database (in the example | ||||
|     below, <literal>postgres</literal>) as a superuser. | ||||
|    </para> | ||||
|    <programlisting> | ||||
| <programlisting> | ||||
| postgres=# -- Create a slot named 'regression_slot' using the output plugin 'test_decoding' | ||||
| postgres=# SELECT * FROM pg_create_logical_replication_slot('regression_slot', 'test_decoding'); | ||||
|     slot_name    | xlog_position | ||||
| @ -139,7 +139,7 @@ postgres=# SELECT pg_drop_replication_slot('regression_slot'); | ||||
| ----------------------- | ||||
| 
 | ||||
| (1 row) | ||||
|     </programlisting> | ||||
| </programlisting> | ||||
|    <para> | ||||
|     The following example shows usage of the walsender interface using | ||||
|     the <link linkend="app-pgrecvlogical"><command>pg_recvlogical</command></link> | ||||
| @ -148,7 +148,7 @@ postgres=# SELECT pg_drop_replication_slot('regression_slot'); | ||||
|     and <varname>max_wal_senders</varname> to be set sufficiently high for | ||||
|     another connection. | ||||
|    </para> | ||||
|    <programlisting> | ||||
| <programlisting> | ||||
| # pg_recvlogical -d postgres --slot test --create | ||||
| # pg_recvlogical -d postgres --slot test --start -f - | ||||
| CTRL-Z | ||||
| @ -159,7 +159,7 @@ table public.data: INSERT: id[integer]:4 data[text]:'4' | ||||
| COMMIT 693 | ||||
| CTRL-C | ||||
| # pg_recvlogical -d postgres --slot test --drop | ||||
|    </programlisting> | ||||
| </programlisting> | ||||
|   </sect1> | ||||
|   <sect1 id="logicaldecoding-explanation"> | ||||
|    <title>Logical Decoding Concepts</title> | ||||
| @ -317,7 +317,7 @@ CTRL-C | ||||
|      <function>_PG_output_plugin_init</function>. This function is passed a | ||||
|      struct that needs to be filled with the callback function pointers for | ||||
|      individual actions. | ||||
|      <programlisting> | ||||
| <programlisting> | ||||
| typedef struct OutputPluginCallbacks | ||||
| { | ||||
|     LogicalDecodeStartupCB startup_cb; | ||||
| @ -326,8 +326,9 @@ typedef struct OutputPluginCallbacks | ||||
|     LogicalDecodeCommitCB commit_cb; | ||||
|     LogicalDecodeShutdownCB shutdown_cb; | ||||
| } OutputPluginCallbacks; | ||||
| 
 | ||||
| typedef void (*LogicalOutputPluginInit)(struct OutputPluginCallbacks *cb); | ||||
|      </programlisting> | ||||
| </programlisting> | ||||
|      The <function>begin_cb</function>, <function>change_cb</function> | ||||
|      and <function>commit_cb</function> callbacks are required, | ||||
|      while <function>startup_cb</function> | ||||
| @ -344,10 +345,10 @@ typedef void (*LogicalOutputPluginInit)(struct OutputPluginCallbacks *cb); | ||||
|      accessed that either have been created by <command>initdb</command> in | ||||
|      the <literal>pg_catalog</literal> schema, or have been marked as user | ||||
|      provided catalog tables using | ||||
|      <programlisting> | ||||
| <programlisting> | ||||
| ALTER TABLE user_catalog_table SET (user_catalog_table = true); | ||||
| CREATE TABLE another_catalog_table(data text) WITH (user_catalog_table = true); | ||||
|      </programlisting> | ||||
| </programlisting> | ||||
|      Any actions leading to xid assignment are prohibited. That, among others, | ||||
|      includes writing to tables, performing DDL changes and | ||||
|      calling <literal>txid_current()</literal>. | ||||
| @ -385,23 +386,23 @@ CREATE TABLE another_catalog_table(data text) WITH (user_catalog_table = true); | ||||
|       The optional <function>startup_cb</function> callback is called whenever | ||||
|       a replication slot is created or asked to stream changes, independent | ||||
|       of the number of changes that are ready to be put out. | ||||
|       <programlisting> | ||||
| <programlisting> | ||||
| typedef void (*LogicalDecodeStartupCB) ( | ||||
|     struct LogicalDecodingContext *ctx, | ||||
|     OutputPluginOptions *options, | ||||
|     bool is_init | ||||
| ); | ||||
|       </programlisting> | ||||
| </programlisting> | ||||
|       The <literal>is_init</literal> parameter will be true when the | ||||
|       replication slot is being created and false | ||||
|       otherwise. <parameter>options</parameter> points to a struct of options | ||||
|       that output plugins can set: | ||||
|       <programlisting> | ||||
| <programlisting> | ||||
| typedef struct OutputPluginOptions | ||||
| { | ||||
|     OutputPluginOutputType output_type; | ||||
| } OutputPluginOptions; | ||||
|       </programlisting> | ||||
| </programlisting> | ||||
|       <literal>output_type</literal> has to either be set to | ||||
|       <literal>OUTPUT_PLUGIN_TEXTUAL_OUTPUT</literal> | ||||
|       or <literal>OUTPUT_PLUGIN_BINARY_OUTPUT</literal>. | ||||
| @ -420,11 +421,11 @@ typedef struct OutputPluginOptions | ||||
|       whenever a formerly active replication slot is not used anymore and can | ||||
|       be used to deallocate resources private to the output plugin. The slot | ||||
|       isn't necessarily being dropped, streaming is just being stopped. | ||||
|       <programlisting> | ||||
| <programlisting> | ||||
| typedef void (*LogicalDecodeShutdownCB) ( | ||||
|     struct LogicalDecodingContext *ctx | ||||
| ); | ||||
|       </programlisting> | ||||
| </programlisting> | ||||
|      </para> | ||||
|    </sect3> | ||||
|     <sect3 id="logicaldecoding-output-plugin-begin"> | ||||
| @ -433,12 +434,12 @@ typedef void (*LogicalDecodeShutdownCB) ( | ||||
|       The required <function>begin_cb</function> callback is called whenever a | ||||
|       start of a commited transaction has been decoded. Aborted transactions | ||||
|       and their contents never get decoded. | ||||
|       <programlisting> | ||||
| <programlisting> | ||||
| typedef void (*LogicalDecodeBeginCB) ( | ||||
|     struct LogicalDecodingContext *, | ||||
|     ReorderBufferTXN *txn | ||||
| ); | ||||
|       </programlisting> | ||||
| </programlisting> | ||||
|       The <parameter>txn</parameter> parameter contains meta information about | ||||
|       the transaction, like the timestamp at which it has been committed and | ||||
|       its XID. | ||||
| @ -452,12 +453,12 @@ typedef void (*LogicalDecodeBeginCB) ( | ||||
|       decoded. The <function>change_cb</function> callbacks for all modified | ||||
|       rows will have been called before this, if there have been any modified | ||||
|       rows. | ||||
|       <programlisting> | ||||
| <programlisting> | ||||
| typedef void (*LogicalDecodeCommitCB) ( | ||||
|     struct LogicalDecodingContext *, | ||||
|     ReorderBufferTXN *txn | ||||
| ); | ||||
|       </programlisting> | ||||
| </programlisting> | ||||
|      </para> | ||||
|     </sect3> | ||||
|     <sect3 id="logicaldecoding-output-plugin-change"> | ||||
| @ -470,14 +471,14 @@ typedef void (*LogicalDecodeCommitCB) ( | ||||
|       or <command>DELETE</command>. Even if the original command modified | ||||
|       several rows at once the callback will be called indvidually for each | ||||
|       row. | ||||
|       <programlisting> | ||||
| <programlisting> | ||||
| typedef void (*LogicalDecodeChangeCB) ( | ||||
|     struct LogicalDecodingContext *ctx, | ||||
|     ReorderBufferTXN *txn, | ||||
|     Relation relation, | ||||
|     ReorderBufferChange *change | ||||
| ); | ||||
|       </programlisting> | ||||
| </programlisting> | ||||
|       The <parameter>ctx</parameter> and <parameter>txn</parameter> parameters | ||||
|       have the same contents as for the <function>begin_cb</function> | ||||
|       and <function>commit_cb</function> callbacks, but additionally the | ||||
| @ -513,11 +514,11 @@ typedef void (*LogicalDecodeChangeCB) ( | ||||
|     <para> | ||||
|      The following example shows how to output data to the consumer of an | ||||
|      output plugin: | ||||
|      <programlisting> | ||||
| <programlisting> | ||||
| OutputPluginPrepareWrite(ctx, true); | ||||
| appendStringInfo(ctx->out, "BEGIN %u", txn->xid); | ||||
| OutputPluginWrite(ctx, true); | ||||
|      </programlisting> | ||||
| </programlisting> | ||||
|     </para> | ||||
|    </sect2> | ||||
|   </sect1> | ||||
|  | ||||
| @ -1315,9 +1315,9 @@ the connection to be used for logical replication from that database. | ||||
|  connection via <application>psql</application> or any other <literal>libpq</literal>-using | ||||
|  tool with a connection string including the <literal>replication</literal> option, | ||||
|  e.g.: | ||||
|  <programlisting> | ||||
|   psql "dbname=postgres replication=database" -c "IDENTIFY_SYSTEM;" | ||||
|  </programlisting> | ||||
| <programlisting> | ||||
| psql "dbname=postgres replication=database" -c "IDENTIFY_SYSTEM;" | ||||
| </programlisting> | ||||
|  However it is often more useful to use | ||||
|  <application>pg_receivexlog</application> (for physical replication) or | ||||
|  <application>pg_recvlogical</application> (for logical replication). | ||||
|  | ||||
| @ -23,7 +23,7 @@ | ||||
|   Typical output from this plugin, used over the SQL logical decoding | ||||
|   interface, might be: | ||||
| 
 | ||||
|   <programlisting> | ||||
| <programlisting> | ||||
| postgres=# SELECT * FROM pg_logical_slot_get_changes('test_slot', NULL, NULL, 'include-xids', '0'); | ||||
|  location  | xid |                       data | ||||
| -----------+-----+-------------------------------------------------- | ||||
| @ -36,7 +36,7 @@ postgres=# SELECT * FROM pg_logical_slot_get_changes('test_slot', NULL, NULL, 'i | ||||
|  0/16D3398 | 692 | table public.data: DELETE: id[int4]:3 | ||||
|  0/16D3398 | 692 | COMMIT | ||||
| (8 rows) | ||||
|   </programlisting> | ||||
| </programlisting> | ||||
|  </para> | ||||
| 
 | ||||
| </sect1> | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user