検索
ホームページバックエンド開発Python チュートリアルFastAPIでデータベース接続とトランザクション処理を実装する方法

FastAPIでデータベース接続とトランザクション処理を実装する方法

Jul 30, 2023 am 11:45 AM
トランザクション処理fastapiデータベース接続性

FastAPI でデータベース接続とトランザクション処理を実装する方法

はじめに:
Web アプリケーションの急速な開発に伴い、データベース接続とトランザクション処理が非常に重要なトピックになっています。 FastAPI は、その速度と使いやすさで開発者に愛されている高性能 Python Web フレームワークです。この記事では、信頼性が高く効率的な Web アプリケーションを構築するために役立つ、FastAPI でデータベース接続とトランザクションを実装する方法を紹介します。

パート 1: データベース接続
FastAPI では、SQLAlchemy や Tortoise-ORM などのさまざまなデータベース接続ツールを使用できます。 SQLAlchemy を例として使用して説明します。

  1. SQLAlchemy と MySQL ドライバーをインストールする
    まず、SQLAlchemy ライブラリと対応する MySQL ドライバーをインストールする必要があります。次のコマンドを使用してインストールできます。
pip install sqlalchemy
pip install mysql-connector-python
  1. データベース接続の作成
    FastAPI アプリケーションでは、メイン アプリケーションでデータベース接続を作成し、プロセス中のルート処理に挿入できます。以下はサンプル コードです:
from fastapi import Depends, FastAPI
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm.session import Session

app = FastAPI()

SQLALCHEMY_DATABASE_URL = "mysql+mysqlconnector://user:password@localhost/db_name"

engine = create_engine(
    SQLALCHEMY_DATABASE_URL,
    pool_size=10,
    max_overflow=20
)
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
Base = declarative_base()

async def get_db() -> Session:
    try:
        db = SessionLocal()
        yield db
    finally:
        db.close()

上記のコードでは、最初にデータベース接続の URL を作成し、次に SQLAlchemy の create_engine 関数を使用してデータベース エンジンを作成します。次に、データベース セッションを維持するための SessionLocal クラスを定義します。最後に、各リクエスト ハンドラーで使用するデータベース セッション インスタンスを返す依存関係関数 get_db を作成します。

パート 2: トランザクション処理
FastAPI では、トランザクション処理を使用してデータベース操作の原子性と一貫性を確保できます。以下は、FastAPI でトランザクションを使用する方法を示すサンプル コードです。

  1. 依存関係を使用したデータベース セッションの挿入
    この例で前に作成した get_db 依存関係関数を引き続き使用し、ルート ハンドラーにデータベース セッションを挿入します。
from fastapi import Depends, FastAPI
from sqlalchemy.orm import Session
from .models import User
from .crud import create_user
from .database import get_db

app = FastAPI()

@app.post("/users/")
async def create_user_handler(user: User, db: Session = Depends(get_db)):
    return create_user(db=db, user=user)

上記のコードでは、ユーザー オブジェクトとデータベース セッションをパラメーターとして受け入れるルート ハンドラー create_user_handler を定義します。このハンドラーでは、データベースに新しいユーザーを作成する create_user という関数を呼び出します。

  1. トランザクション処理の実装
    次に、create_user 関数の例のコードを示します。これは、データベース セッションでトランザクション処理を使用する方法を示しています。上記のコードでは、まず db.begin() ステートメントを使用してトランザクションを開始します。次に、db.add() ステートメントを使用して、ユーザー オブジェクトをデータベース セッションに追加します。次に、db.commit() ステートメントを使用してトランザクションをデータベースにコミットします。コミットプロセス中にエラーが発生した場合、db.rollback() ステートメントを使用してトランザクションをロールバックします。最後に、db.refresh() ステートメントを使用してユーザー オブジェクトを更新し、データベースで生成された主キー値が含まれていることを確認します。
結論:

この記事では、FastAPI でデータベース接続とトランザクション処理を実装する方法を紹介しました。まず SQLAlchemy を使用してデータベース接続を作成し、次に依存関係関数を使用してデータベース セッションをルート ハンドラーに挿入しました。次に、データベース セッション内でトランザクションを使用して、データベース操作のアトミック性と一貫性を保証する方法を示しました。これらのテクニックを学び実践することで、信頼性が高く効率的な Web アプリケーションを構築できるようになります。

以上がFastAPIでデータベース接続とトランザクション処理を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Pythonの主な目的:柔軟性と使いやすさPythonの主な目的:柔軟性と使いやすさApr 17, 2025 am 12:14 AM

Pythonの柔軟性は、マルチパラダイムサポートと動的タイプシステムに反映されていますが、使いやすさはシンプルな構文とリッチ標準ライブラリに由来しています。 1。柔軟性:オブジェクト指向、機能的および手続き的プログラミングをサポートし、動的タイプシステムは開発効率を向上させます。 2。使いやすさ:文法は自然言語に近く、標準的なライブラリは幅広い機能をカバーし、開発プロセスを簡素化します。

Python:汎用性の高いプログラミングの力Python:汎用性の高いプログラミングの力Apr 17, 2025 am 12:09 AM

Pythonは、初心者から上級開発者までのすべてのニーズに適した、そのシンプルさとパワーに非常に好まれています。その汎用性は、次のことに反映されています。1)学習と使用が簡単、シンプルな構文。 2)Numpy、Pandasなどの豊富なライブラリとフレームワーク。 3)さまざまなオペレーティングシステムで実行できるクロスプラットフォームサポート。 4)作業効率を向上させるためのスクリプトおよび自動化タスクに適しています。

1日2時間でPythonを学ぶ:実用的なガイド1日2時間でPythonを学ぶ:実用的なガイドApr 17, 2025 am 12:05 AM

はい、1日2時間でPythonを学びます。 1.合理的な学習計画を作成します。2。適切な学習リソースを選択します。3。実践を通じて学んだ知識を統合します。これらの手順は、短時間でPythonをマスターするのに役立ちます。

Python vs. C:開発者の長所と短所Python vs. C:開発者の長所と短所Apr 17, 2025 am 12:04 AM

Pythonは迅速な開発とデータ処理に適していますが、Cは高性能および基礎となる制御に適しています。 1)Pythonは、簡潔な構文を備えた使いやすく、データサイエンスやWeb開発に適しています。 2)Cは高性能で正確な制御を持ち、ゲームやシステムのプログラミングでよく使用されます。

Python:時間のコミットメントと学習ペースPython:時間のコミットメントと学習ペースApr 17, 2025 am 12:03 AM

Pythonを学ぶのに必要な時間は、人によって異なり、主に以前のプログラミングの経験、学習の動機付け、学習リソースと方法、学習リズムの影響を受けます。現実的な学習目標を設定し、実用的なプロジェクトを通じて最善を尽くします。

Python:自動化、スクリプト、およびタスク管理Python:自動化、スクリプト、およびタスク管理Apr 16, 2025 am 12:14 AM

Pythonは、自動化、スクリプト、およびタスク管理に優れています。 1)自動化:OSやShutilなどの標準ライブラリを介してファイルバックアップが実現されます。 2)スクリプトの書き込み:Psutilライブラリを使用してシステムリソースを監視します。 3)タスク管理:スケジュールライブラリを使用してタスクをスケジュールします。 Pythonの使いやすさと豊富なライブラリサポートにより、これらの分野で優先ツールになります。

Pythonと時間:勉強時間を最大限に活用するPythonと時間:勉強時間を最大限に活用するApr 14, 2025 am 12:02 AM

限られた時間でPythonの学習効率を最大化するには、PythonのDateTime、時間、およびスケジュールモジュールを使用できます。 1. DateTimeモジュールは、学習時間を記録および計画するために使用されます。 2。時間モジュールは、勉強と休息の時間を設定するのに役立ちます。 3.スケジュールモジュールは、毎週の学習タスクを自動的に配置します。

Python:ゲーム、GUIなどPython:ゲーム、GUIなどApr 13, 2025 am 12:14 AM

PythonはゲームとGUI開発に優れています。 1)ゲーム開発は、2Dゲームの作成に適した図面、オーディオ、その他の機能を提供し、Pygameを使用します。 2)GUI開発は、TKINTERまたはPYQTを選択できます。 TKINTERはシンプルで使いやすく、PYQTは豊富な機能を備えており、専門能力開発に適しています。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)