Note
This plugin is part of the community.postgresql collection (version 1.5.0).
You might already have this collection installed if you are using the ansible
package. It is not included in ansible-core
. To check whether it is installed, run ansible-galaxy collection list
.
To install it, use: ansible-galaxy collection install community.postgresql
.
To use it in a playbook, specify: community.postgresql.postgresql_copy
.
The below requirements are needed on the host that executes this module.
Parameter | Choices/Defaults | Comments |
---|---|---|
ca_cert string | Specifies the name of a file containing SSL certificate authority (CA) certificate(s). If the file exists, the server's certificate will be verified to be signed by one of these authorities. aliases: ssl_rootcert | |
columns list / elements=string | List of column names for the src/dst table to COPY FROM/TO. aliases: column | |
copy_from path | Copy data from a file to a table (appending the data to whatever is in the table already). Mutually exclusive with copy_to and src. aliases: from | |
copy_to path | Copy the contents of a table to a file. Can also copy the results of a SELECT query. Mutually exclusive with copy_from and dst. aliases: to | |
db string | Name of database to connect to. aliases: login_db | |
dst string | Copy data to dst=tablename from copy_from=/path/to/data.file. Used with copy_from only. aliases: destination | |
login_host string | Host running the database. If you have connection issues when using localhost , try to use 127.0.0.1 instead. | |
login_password string | The password this module should use to establish its PostgreSQL session. | |
login_unix_socket string | Path to a Unix domain socket for local connections. | |
login_user string | Default: "postgres" | The username this module should use to establish its PostgreSQL session. |
options dictionary | Options of COPY command. See the full list of available options https://www.postgresql.org/docs/current/sql-copy.html. | |
port integer | Default: 5432 | Database port to connect to. aliases: login_port |
program boolean |
| Mark src/dst as a program. Data will be copied to/from a program. See block Examples and PROGRAM arg description https://www.postgresql.org/docs/current/sql-copy.html. |
session_role string | Switch to session_role after connecting. The specified session_role must be a role that the current login_user is a member of. Permissions checking for SQL commands is carried out as though the session_role were the one that had logged in originally. | |
src string | Copy data from copy_from to src=tablename. Used with copy_to only. aliases: source | |
ssl_mode string |
| Determines whether or with what priority a secure SSL TCP/IP connection will be negotiated with the server. See https://www.postgresql.org/docs/current/static/libpq-ssl.html for more information on the modes. Default of prefer matches libpq default. |
trust_input boolean added in 0.2.0 of community.postgresql |
| If no , check whether values of parameters are potentially dangerous.It makes sense to use no only when SQL injections are possible. |
Note
postgres
account on the host.See also
Complete reference of the COPY command documentation.
- name: Copy text TAB-separated data from file /tmp/data.txt to acme table community.postgresql.postgresql_copy: copy_from: /tmp/data.txt dst: acme - name: Copy CSV (comma-separated) data from file /tmp/data.csv to columns id, name of table acme community.postgresql.postgresql_copy: copy_from: /tmp/data.csv dst: acme columns: id,name options: format: csv - name: > Copy text vertical-bar-separated data from file /tmp/data.txt to bar table. The NULL values are specified as N community.postgresql.postgresql_copy: copy_from: /tmp/data.csv dst: bar options: delimiter: '|' null: 'N' - name: Copy data from acme table to file /tmp/data.txt in text format, TAB-separated community.postgresql.postgresql_copy: src: acme copy_to: /tmp/data.txt - name: Copy data from SELECT query to/tmp/data.csv in CSV format community.postgresql.postgresql_copy: src: 'SELECT * FROM acme' copy_to: /tmp/data.csv options: format: csv - name: Copy CSV data from my_table to gzip community.postgresql.postgresql_copy: src: my_table copy_to: 'gzip > /tmp/data.csv.gz' program: yes options: format: csv - name: > Copy data from columns id, name of table bar to /tmp/data.txt. Output format is text, vertical-bar-separated, NULL as N community.postgresql.postgresql_copy: src: bar columns: - id - name copy_to: /tmp/data.csv options: delimiter: '|' null: 'N'
Common return values are documented here, the following are the fields unique to this module:
Key | Returned | Description |
---|---|---|
dst string | always | Data destination. Sample: /tmp/data.csv |
queries string | always | List of executed queries. Sample: ["COPY test_table FROM '/tmp/data_file.txt' (FORMAT csv, DELIMITER ',', NULL 'NULL')"] |
src string | always | Data source. Sample: mytable |
© 2012–2018 Michael DeHaan
© 2018–2021 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
https://docs.ansible.com/ansible/latest/collections/community/postgresql/postgresql_copy_module.html