トップページ -> インストール,設定,利用 -> PostgreSQL -> PostgreSQL 12 のインストール,データベース作成,テーブル定義(Ubuntu 上)
[サイトマップへ], [サイト内検索へ]

PostgreSQL 12 のインストール,データベース作成,テーブル定義(Ubuntu 上)

Ubuntu に,PostgreSQL 12 のインストールを行う. そして,データベース生成,テーブル定義を行ってみる.

※ インストールは,https://wiki.postgresql.org/wiki/Apt に記載の手順に従う.

【このページの目次】

  1. 前準備
  2. PostgreSQL 12 のインストール(Ubuntu 上)
  3. インストール後の確認
  4. データベース作成,テーブル定義(PostgreSQL)

サイト内の関連ページ: データベースのことを含む各種教材は別ページにまとめている.

参考Webページ:


前準備

OS のシステム更新

Ubuntu で OS のシステム更新を行うときは, 端末で,次のコマンドを実行.

sudo apt update
sudo apt -yV upgrade
sudo /sbin/shutdown -r now

PostgreSQL 12 のインストール(Ubuntu 上)

https://wiki.postgresql.org/wiki/Apt に記載の手順に従う.

  1. レポジトリキーのインストール

    sudo apt -yV install curl ca-certificates gnupg
    curl https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
    
  2. パッケージリストの取得
    sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
    

    [image]
  3. パッケージ情報の更新
    sudo apt -y update
    
  4. インストール
    sudo apt -yV install postgresql-12 
    
  5. インストール直後なので,確認のため,サーバを手動で起動して停止してみて,エラーメッセージが出ないことを確認する

    sudo service postgresql start 
    sudo service postgresql stop
    

    [image]

インストール後の確認

  1. PostgreSQL サービス・アカウント (service account)の確認

    PostgreSQL 用サービス・アカウントは,Postgres サーバの起動等に使う.

    Ubuntu でパッケージを使って PostgreSQL をインストールすると,PostgreSQL 用サービス・アカウント(ユーザ名は「postgres」)が自動的に作成される.

    cat /etc/passwd | grep postgres
    

    ※ 「x」は no password という意味(パスワードがないという意味ではない)

    [image]

データベース作成,テーブル定義(PostgreSQL)

事前に決めておく事項

PostgreSQL データベースサーバの起動

sudo service postgresql start 

[image]

PostgreSQL のデータベースディレクトリの作成

ここでは,データベースディレクトリは /var/lib/postgresql/data とする.好きに決めていいが,日本語を含まないディレクトリ名にすること.

sudo mkdir /var/lib/postgresql/data
sudo chown -R postgres:postgres /var/lib/postgresql/data

[image]

データベースファイルの作成

次のコマンドを実行.

sudo su - postgres
/usr/lib/postgresql/12/bin/initdb --encoding='UTF-8' -D /var/lib/postgresql/data

[image]

「sudo su - postgres」は,postgres ユーザに切り替える操作である.

  • 元のユーザに戻るには,「exit」と操作する.

    exit
    

    [image]

    Postgres のサンプルデータベースの作成と権限の設定

    1. psql の起動

      sudo su - postgres
      psql -U postgres
      

      [image]
    2. データベース論理名と,オーナと,文字コード(エンコーディング)を指定して,SQL の create database コマンドを起動

      文字コード(エンコーディング)UTF8で, データベース論理名 testdb のデータベースを作成したいときは, 次のように操作する.

      create database testdb encoding 'UTF8';
      

      [image]
      • -E UTF8 : 文字コード(エンコーディング)
      • testdb : データベース論理名
    3. psql の終了
      \q
      

      [image]
    4. 確認のため,データベースの一覧表示を行なってみる

      PostgreSQL の場合,データベースの一覧表示は,「psql -l」で行う.

      psql -U postgres -l
      

      [image]
    5. 元のユーザに戻るには,「exit」と操作する.

      exit
      

      [image]

    テーブルの定義と作成

    1. psql の起動

      sudo su - postgres
      psql -U postgres -d testdb
      

      [image]
    2. SQL を用いたテーブル定義

      create table order_records (
          id            integer primary key not null,
          year          integer not null CHECK ( year > 2008 ),
          month         integer not null CHECK ( month >= 1 AND month <= 12 ),
          day           integer not null CHECK ( day >= 1 AND day <= 31 ),
          customer_name text not null,
          product_name  text not null,
          unit_price    real not null check ( unit_price > 0 ),
          qty           integer not null default 1 check ( qty > 0 ),
          created_at    timestamp with time zone not null,
          updated_at    timestamp with time zone,
          check ( ( unit_price * qty ) < 200000 ) );
      

      [image]
    3. SQL を用いたテーブル生成

      begin transaction;
      insert into order_records values( 1, 2020, 7, 26,  'kaneko', 'orange A', 1.2, 10, current_timestamp, NULL );
      insert into order_records (id, year, month, day, customer_name, product_name, unit_price, qty, created_at) values( 2, 2020, 7, 26,  'miyamoto', 'Apple M',  2.5, 2, current_timestamp );
      insert into order_records (id, year, month, day, customer_name, product_name, unit_price, qty, created_at) values( 3, 2020, 7, 27,  'kaneko',   'orange B', 1.2, 8, current_timestamp );
      insert into order_records (id, year, month, day, customer_name, product_name, unit_price, created_at) values( 4, 2020, 7, 28,  'miyamoto',   'Apple L', 3, current_timestamp );
      commit;
      

      [image]
    4. 確認表示

      select * from order_records;
      

      [image]
    5. psql の終了
      \q
      

      [image]

    本サイトは金子邦彦研究室のWebページです.サイトマップは,サイトマップのページをご覧下さい. 本サイト内の検索は,サイト内検索のページをご利用下さい.

    問い合わせ先: 金子邦彦(かねこ くにひこ) [image]