PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Utwórz tabelę w obrazie dokowanym PostgreSQL

W skrypcie docker-entrypoint.sh oficjalnego obrazu dockera postgresów jest napisane:

psql+=( --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" )

        echo
        for f in /docker-entrypoint-initdb.d/*; do
            case "$f" in
                *.sh)     echo "$0: running $f"; . "$f" ;;
                *.sql)    echo "$0: running $f"; "${psql[@]}" < "$f"; echo ;;
                *.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${psql[@]}"; echo ;;
                *)        echo "$0: ignoring $f" ;;
            esac
            echo
done

Tak więc każdy plik .sql, który chcesz wykonać w obrazie Docker, można po prostu umieścić w tym folderze. Więc mój plik docker wygląda tak

FROM postgres:9.3
ENV POSTGRES_USER docker
ENV POSTGRES_PASSWORD docker
ENV POSTGRES_DB docker
ADD CreateDB.sql /docker-entrypoint-initdb.d/

I zawartość mojego CreateDB.sql:

CREATE TABLE web_origins (
    client_id character varying(36) NOT NULL,
    value character varying(255)
);

Więc po prostu zaczynam mój kontener od:

docker run -d my-postgres

Aby sprawdzić:

docker exec -it 6250aee43d12 bash
[email protected]:/# psql -h localhost -p 5432 -U docker -d docker
psql (9.3.13)
Type "help" for help.

docker=# \c
You are now connected to database "docker" as user "docker".
docker=# \dt
           List of relations
 Schema |    Name     | Type  | Owner
--------+-------------+-------+--------
 public | web_origins | table | docker
(1 row)

Szczegóły mysql tutaj w tym blogu .




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Podwójny cudzysłów w nazwie tabeli w zapytaniu wybierającym PostgreSQL

  2. Jaka jest maksymalna liczba kolumn w zapytaniu wybierającym PostgreSQL?

  3. Dlaczego PostgreSQL uważa, że ​​granice NULL w typach zakresów różnią się od granic nieskończonych?

  4. Jak warunkowo UPDATE/INSERT po DELETE, który nie znajduje wierszy?

  5. Czy istnieje sposób na indeksowanie w postgresie w celu szybkiego wyszukiwania podciągów?