Pythonでデータベースを構築!設定方法や使用方法も解説

Python(Django)のデータベース、SQLiteとは?
この記事では、Pythonでデータベースを扱う方法について書いていきます。例として、PythonのWebシステムフレームワークDjangoでSQLiteというデータベースを扱う方法を取り上げます。SQLiteは、Djangoのデフォルトのデータベースです。アクセスが集中するとパフォーマンスが劣るという欠点はあるものの、手軽さによる開発の迅速さからスタート時のデータベース(特にスモールスタート)としては最適でしょう。データベースの性能がボトルネックになってきたら、MySQLやPostgreSQLに移行すればよいのです。Pythonでは、移行も簡単にできます。
SQLiteは、データベース全体が一つのファイルになっています。しかし、データベースなので、ファイルへのアクセスということはまったく気にしません。データベースにアクセスする際には、専用の命令文を用います。通常、データベースにアクセスする際にはSQLという独自のデータベースアクセス言語を書く必要があります。ところがPython(Django)では、SQLを書く必要はよほどの場合を除きありません。SQLを覚える必要がなく、迅速な開発を可能にします。
SQLiteの設定方法
Djangoの構築方法については割愛します。ここではDjangoがインストールされており、プロジェクトやアプリが構築されていて既に使える状態になっているとします。SQLiteの構築に、何か特別なことをする必要はありません。Pythonでは、Djangoをインストールした段階で、すでにSQLiteが構築されており、使用できる状態になっています。
構築したDjangoプロジェクトのフォルダの中のプロジェクト名フォルダ(Djangoではおなじみの、プロジェクト全体の設定フォルダ)のsettings.pyの中に以下のような記述があるはずです。DATABASES = { ‘default’: { ‘ENGINE’: ‘django.db.backends.sqlite3’, ‘NAME’: os.path.join(BASE_DIR, ‘db.sqlite3’), }}この記述があれば、SQLiteが使える状態になっています。
SQLiteの構築方法
Python(Django)で実際にアプリをデプロイし、SQLiteを構築するには、プロジェクトのフォルダで以下の2つのコマンドを実行してください。python manage.py makemigrations アプリ名python manage.py migrateこれでSQLiteにコードの内容が反映されます。また、テーブルが構築され、データベースとして使えるようになります。
SQLiteの使用方法
ここではPython(Django)でSQLiteを使用する方法を見ていきます。
テーブルを作る
Pythonでテーブルを構築するのに、何か特別なことをする必要はありません。Djangoのアプリ内に生成されたmodels.pyの中に、以下のようなクラスを書くだけで大丈夫です。
class ChatData(models.Model): guest_id = models.IntegerField(default=0) host_id = models.IntegerField(default=0) name = models.CharField(max_length=20,blank=True) time = models.CharField(max_length=20,blank=True) talk = models.CharField(max_length=1000,blank=True)
これは筆者が構築した一対一のチャットシステムのPythonコードです。チャットデータを保管するテーブルです。guest_id:発言したルームのゲストのIDhost_id:発言したルームのホストのIDname:発言者の名前time:発言の時刻talk:発言の文章となっています。~Fieldというのが、Python(Django)でのデータベースのカラム構築方法です。詳しくは下記のリンクを参照してください。
データを抽出する
以下、このチャットのデータベースを例に、Pythonのコードを解説していきます。データを抽出するのには、次のようにします。data = ChatData.objects.filter(guest_id=g_id)ChatData.objectsというのは、Djangoシステム内で稼働しているデータベースのオブジェクトを指します。filter関数で、「どんなデータを抽出するか」を指定します。この場合、「guest_idフィールドがg_idだったら」です。SQLだとSELECTに相当する内容ですが、Pythonだと、このように書けます。
データを挿入する
データを挿入するには、次のようなコードを書きます。chatdata = ChatData(guest_id=g_id, host_id=h_id, name=save_name, time=time, talk=talk)chatdata.save()ここでg_id、h_id、save_name、time、talkにはそれなりの値が入っています。左辺の変数名は、フィールドの名前です。それでChatDataの新しいオブジェクトを作り、chatdata.save()で追加します。SQLだとINSERTに相当する内容です。
データを更新する
データを更新するには、抽出と挿入を組み合わせます。更新したい行を抽出し、更新するフィールドを書き換えて、save()で更新します。SQLだとUPDATEに相当する内容です。
トランザクション
トランザクションとは、データベースの更新処理において、整合性を保つために必要な処理です。たとえば、A、B双方が同時にWebシステムにアクセスしていてMというデータを変える場合、1,AがMの情報を取得する。2,BがMの情報を取得する。3,AがMに1足してMを更新する。4,BがMに2足してMを更新する。という流れでMが更新されると、Aの更新内容は無視されて、Bが行なった2を足す内容だけが反映されてMのデータの整合性が保たれません。
これを避けるためにトランザクション処理というものが用いられます。具体的に言うと、AがMの値を更新するまで、BはMの情報を更新のために取得することはできないようにします(表示のための取得は許されます)。
DjangoでのSQLiteのトランザクション処理の追加は簡単です。settings.pyを以下のように書き換えてください。DATABASES = { ‘default’: { ‘ENGINE’: ‘django.db.backends.sqlite3’, ‘NAME’: os.path.join(BASE_DIR, ‘db.sqlite3’), ‘ATOMIC_REQUESTS’: True }}ATOMIC_REQUESTSを追加するだけです。これだけで、「リクエストごとのトランザクション」を自動でDjangoが付けてくれます。
Djangoでは、データベースを楽に使える!
Djangoでは、データベースを楽に使えるということが分かったのではないでしょうか。SQLiteを使えば、データベースの構築が実に手軽です。それでいてきちんとしたデータの整合性を保てるので、自分でファイル処理を実装するのは効率の面から言って非現実的でしょう。DjangoでWebシステムを構築する際には、SQLiteを使って開発スピードを上げましょう。
FEnetを運営しているネプラス株式会社はサービス開始から10年以上
『エンジニアの生涯価値の向上』をミッションに掲げ、
多くのインフラエンジニア・ネットワークエンジニアの就業を支援してきました。
ネプラス株式会社はこんな会社です
秋葉原オフィスにはネプラス株式会社をはじめグループのIT企業が集結!
数多くのエンジニアが集まります。

-
インフラ業界に特化
ネットワーク・サーバー・データベース等、ITインフラ業界に特化。Cisco Systemsプレミアパートナーをはじめ各種ベンダーのパートナー企業です。
業界を知り尽くしているからこそ大手の取引先企業、経験豊富なエンジニアに選ばれています。
-
正社員なのにフリーランスのような働き方
正社員の方でも希望を聞いたうえでプロジェクトをアサインさせていただいており、フリーランスのような働き方が可能。帰社日もありません。
プロジェクト終了後もすぐに次の案件をご紹介させていただきますのでご安心ください。
-
大手直取引の高額案件
案件のほとんどが大手SIerやエンドユーザーからの直取引のためエンジニアの皆様へに高く還元できています。
Ciscoをはじめ、Juniper、Azure、Linux、AWS等インフラに特化した常時300件以上の案件があります。
-
スキルアップ支援
不要なコストを削減し、その分エンジニアの方へのスキルアップ支援(ネットワーク機器貸出、合格時の受験費用支給など)や給与で還元しています。
受験費用例)CCNP,CCIE:6-20万円、JNCIS:3-4万円、AWS:1-3万円など
※業務に関連する一定の資格のみ。各種条件がありますので詳しくは担当者へにお尋ねください。
-
現給与を保証します!※
前職の給与保証しており、昨年度は100%の方が給与アップを実現。収入面の不安がある方でも安心して入社していただけます。
※適用にはインフラエンジニアの業務経験1年以上、等一定の条件がございます。
-
インセンティブ制度
ネットワーク機器の販売・レンタル事業等、売上に貢献いただいた方にはインセンティブをお支払いしています。
取引先企業とエンジニア側、双方にメリットがあり大変好評をいただいています。
-
社会保険・福利厚生
社員の方は、社会保険を完備。健康保険は業界内で最も評価の高い「関東ITソフトウェア健康保険組合」です。
さらに様々なサービスをお得に利用できるベネフィットステーションにも加入いただきます。
-
東証プライム上場企業グループ
ネプラスは東証プライム上場「株式会社夢真ビーネックスグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
ネプラス株式会社に興味を持った方へ
ネプラス株式会社では、インフラエンジニアを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
オンライン面接も随時受付中。ぜひお気軽にご応募ください。


Python新着案件New Job
-
【高額年収】/ネットワーク設計構築検証/神奈川県平塚市/【WEB面談可】/在宅勤務/20代~40代の方活躍中
年収660万~660万円神奈川県平塚市(平塚駅) -
SaaS向けデータ連携システムの移行/Python/東京都渋谷区/【WEB面談可】/在宅勤務/20代~40代の方活躍中
年収780万~780万円東京都渋谷区(恵比寿駅) -
【高額年収】/構成管理ツール運用保守/東京都23区西部/【WEB面談可/インフラサーバ経験者/20~40代の方活躍中】/在宅勤務
年収600万~720万円東京都23区西部(-駅) -
【高額年収】/CI/CD環境の運用保守/東京都23区西部/【WEB面談可/インフラサーバ経験者/20~40代の方活躍中】/在宅勤務
年収600万~720万円東京都23区西部(-駅) -
CI/CD環境設計構築のテスター/東京都23区西部/【WEB面談可/インフラサーバ経験者/20~40代の方活躍中】/在宅勤務
年収300万~420万円東京都23区西部(-駅) -
【高額年収】/クラウドインフラ構築/Linux/東京都港区/【WEB面談可】/在宅勤務/20代~40代の方活躍中
年収720万~840万円東京都港区(浜松町駅)