PythonPostgreSQL-データベースの作成

CREATE DATABASEステートメントを使用して、PostgreSQLでデータベースを作成できます。コマンドの後に作成するデータベースの名前を指定することにより、PostgreSQLシェルプロンプトでこのステートメントを実行できます。

構文

以下は、CREATEDATABASEステートメントの構文です。

CREATE DATABASE dbname;

次のステートメントは、PostgreSQLでtestdbという名前のデータベースを作成します。

postgres=# CREATE DATABASE testdb;
CREATE DATABASE

\ lコマンドを使用して、PostgreSQLでデータベースを一覧表示できます。データベースのリストを確認すると、新しく作成されたデータベースは次のようになります。

postgres=# \l
                                           List of databases
Name       | Owner    | Encoding | Collate                    | Ctype       |
-----------+----------+----------+----------------------------+-------------+
mydb       | postgres | UTF8     | English_United States.1252 | ........... |
postgres   | postgres | UTF8     | English_United States.1252 | ........... |
template0  | postgres | UTF8     | English_United States.1252 | ........... |
template1  | postgres | UTF8     | English_United States.1252 | ........... |
testdb     | postgres | UTF8     | English_United States.1252 | ........... |
(5 rows)

SQLステートメントCREATEDATABASEのラッパーであるコマンドcreatedbを使用して、コマンドプロンプトからPostgreSQLでデータベースを作成することもできます。

C:\Program Files\PostgreSQL\11\bin> createdb -h localhost -p 5432 -U postgres sampledb
Password:

Pythonを使用してデータベースを作成する

psycopg2のカーソルクラスは、さまざまなPostgreSQLコマンドを実行し、レコードをフェッチし、データをコピーするさまざまなメソッドを提供します。Connectionクラスのcursor()メソッドを使用して、カーソルオブジェクトを作成できます。

このクラスのexecute()メソッドは、PostgreSQLクエリをパラメータとして受け入れて実行します。

したがって、PostgreSQLでデータベースを作成するには、このメソッドを使用してCREATEDATABASEクエリを実行します。

次のPythonの例では、PostgreSQLデータベースにmydbという名前のデータベースを作成します。

import psycopg2

#establishing the connection
conn = psycopg2.connect(
   database="postgres", user='postgres', password='password', host='127.0.0.1', port= '5432'
)
conn.autocommit = True

#Creating a cursor object using the cursor() method
cursor = conn.cursor()

#Preparing query to create a database
sql = '''CREATE database mydb''';

#Creating a database
cursor.execute(sql)
print("Database created successfully........")

#Closing the connection
conn.close()

出力

Database created successfully........