Python での SQLAlchemy リレーショナル操作の概要 (コード付き)
リレーショナル データベースはリレーショナル モデルに基づいたデータベースであるため、データベース プログラミングではテーブル間の関係が特に重要です。このセクションでは、読者が SQLAlchemy のリレーションシップ操作をすぐにマスターできるように、SQLAlchemy でリレーションシップを定義する方法と、リレーションシップを使用してクエリを実行する方法に焦点を当てます。
1. ケース
3 つのエンティティ テーブル: クラス テーブル、学生テーブル、教師テーブル、および 1 つのリレーショナル テーブル: class_Teacher を設計します。クラスと生徒の間には 1 対多の関係があり、クラスと教師の間には多対多の関係があります。
from sqlalchemy import Table,Column,Integer,ForeignKey,String from sqlalchemy.orm import relationship,backref from sqlalchemy.ext.declarative import declarative_base Base=declarative_base() class Class(Base): __tablename__='class' class_id=Column(Integer,primary_key=True) name=Column(String(50)) level=Column(Integer) address=Column(String(50)) class_teachers=relationship("ClassTeacher",backref="class") students=relationship("Student",backref="class") class Student(Base): __tablename__='student' student_id=Column(Integer,primary_key=True) name=Column(String(50)) age=Column(Integer) gender=Column(String(10)) address=Column(String(50)) class_id=Column(Integer,ForeignKey('class.id')) class Teacher(Base): __tablename__='teacher' teacher_id=Column(Integer,primary_key=True) name=Column(String(50)) gender=Column(String(10)) telephone=Column(String(50)) address=Column(String(50)) class_teachers=relationship("ClassTeacher",backref="teacher") class ClassTeacher(Base): __tablename__='class_teacher' teacher_id=Column(Integer,ForeignKey('teacher.teacher_id'),primary_key=True) class_id=Column(Integer,ForeignKey("class.id"),primary_key=True)
コードは 4 つの SQLAlchemy モデルを使用して 4 つのテーブルを定義します。関係定義に関連する部分は次のとおりです:
外部キーの設定: 列内定義では、列のForeignKeyを渡して外部キーを設定します。
class_id=Column(Integer,ForeignKey('class.id'))
リレーションシップ設定: リレーションシップ キーワードを使用して、親モデルの単語テーブルへの参照を確立します。たとえば、クラス モデルのリレーションシップ設定は次のようになります。
students=relationship("Student",backref="calss")
backref パラメータはオプションのパラメータです。backref が設定されている場合、このステートメントは親テーブルから子テーブルへの参照も設定します。
1 対多の関係の使用: 将来的には、students 属性を通じて、関連するクラスのすべての学生の情報を直接取得できるようになります。次のコードは、クラス [クラス 3、クラス 2] のすべての生徒情報を出力できます。
class=session.query(Class).filter(Clss.name=="三年二班").first() for student in class_.students: print(student)
多対多の関係の使用: 関連するモデル ClassTeacher を通じて実装され、モデル Class と Teacher の外部キーがそれぞれ設定されます。と親モデルに設定される 対応関係が実装されます。多対多の関係は、2 つの親テーブル間の多対 1 の関係を実装する関連付けテーブルとして考えることもできます。クラスと教師の間には多対多の関係があります。次のコードは、クラス内のすべての教師の情報を出力できます [クラス 2、グレード 3]
class=session.query(Class).filter(Class.name=="三年二班").first() for class_teacher in class_.class_teachers: teacher=class_teacher.teacher print(teacher)
2. 接続クエリ
実際の開発ではリレーションシップがある場合、複数テーブルの接続クエリが必須となります。以下は、複数テーブルの結合クエリを実行する方法を示す実際的な例です。
クエリ ステートメントで join キーワードを使用すると、接続クエリを実行し、3 年生全員の名前を出力できます:
students=session.query(Student).join(Class).filter(Class.level==3).all() for student in students: print(student.namr)
上記のクエリ関数は自動的に外部キーを使用します。このクエリは、SQLAlchemy によって次の SQL ステートメントに自動的に変換され、実行されます:
SELECT student.student_id AS student_student_id, student.name AS student.name, student.age AS student.age, student.gender AS student.gender, student.address AS student.address, student.class_id AS student_class_id FROM student JOIN class ON student.class_id=class.class_id WHERE class.leve=? (3,)
接続されたテーブルの内部を出力する必要がある場合は、複数のテーブル オブジェクトを指定できます。クエリ。
次のステートメントは、3 年生全員の名前とクラスの名前を出力します。
for student,class_ in session.query(Student,Class).join(Class).filter(Class.level==3).all(): print(student.name,class_.name)
上記のクエリ関数は、外部キー関係を接続条件として自動的に使用します。クエリは SQLAlchemy によって次の SQL ステートメントに自動的に変換され、実行されます:
SELECT student.student_id AS student_student_id, student.name AS student.name, student.age AS student.age, student.gender AS student.gender, student.address AS student.address, student.class_id AS student_class_id, class.class_id AS class_class_id, class.name AS class_name, class.level AS class_level, class.address AS class_location FROM student JOIN class ON student.class_id=class.class_id WHERE class.leve=? (3,)
If you need to外部キー以外の他のフィールドを結合時に使用します。接続条件は開発者が設定する必要があります。以下は、クラスアドレスが学生のアドレスと同じである学生の名前を出力します。
for student_name, in session.query(Student.name).join(Class,Class.address==Student.address).filter(Class.level==3).all(): print(student_name)
上記のクエリ関数は、開発者が接続条件として指定したステートメントに基づいており、フィールドがクエリを直接指定すると、クエリが削減されます。 実際の SQL でクエリされるフィールドは、パフォーマンスを向上させます。クエリは SQLAlchemy によって実行のために次の SQL ステートメントに自動的に変換されます:
SELECT student.name AS student_name, FROM student JOIN class ON student.address=class.address
以上がPython での SQLAlchemy リレーショナル操作の概要 (コード付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









PHPは主に手順プログラミングですが、オブジェクト指向プログラミング(OOP)もサポートしています。 Pythonは、OOP、機能、手続き上のプログラミングなど、さまざまなパラダイムをサポートしています。 PHPはWeb開発に適しており、Pythonはデータ分析や機械学習などのさまざまなアプリケーションに適しています。

PHPはWeb開発と迅速なプロトタイピングに適しており、Pythonはデータサイエンスと機械学習に適しています。 1.PHPは、単純な構文と迅速な開発に適した動的なWeb開発に使用されます。 2。Pythonには簡潔な構文があり、複数のフィールドに適しており、強力なライブラリエコシステムがあります。

VSコードはPythonの書き込みに使用でき、Pythonアプリケーションを開発するための理想的なツールになる多くの機能を提供できます。ユーザーは以下を可能にします。Python拡張機能をインストールして、コードの完了、構文の強調表示、デバッグなどの関数を取得できます。デバッガーを使用して、コードを段階的に追跡し、エラーを見つけて修正します。バージョンコントロールのためにGitを統合します。コードフォーマットツールを使用して、コードの一貫性を維持します。糸くずツールを使用して、事前に潜在的な問題を発見します。

VSコードはWindows 8で実行できますが、エクスペリエンスは大きくない場合があります。まず、システムが最新のパッチに更新されていることを確認してから、システムアーキテクチャに一致するVSコードインストールパッケージをダウンロードして、プロンプトとしてインストールします。インストール後、一部の拡張機能はWindows 8と互換性があり、代替拡張機能を探すか、仮想マシンで新しいWindowsシステムを使用する必要があることに注意してください。必要な拡張機能をインストールして、適切に動作するかどうかを確認します。 Windows 8ではVSコードは実行可能ですが、開発エクスペリエンスとセキュリティを向上させるために、新しいWindowsシステムにアップグレードすることをお勧めします。

VSコード拡張機能は、悪意のあるコードの隠れ、脆弱性の活用、合法的な拡張機能としての自慰行為など、悪意のあるリスクを引き起こします。悪意のある拡張機能を識別する方法には、パブリッシャーのチェック、コメントの読み取り、コードのチェック、およびインストールに注意してください。セキュリティ対策には、セキュリティ認識、良好な習慣、定期的な更新、ウイルス対策ソフトウェアも含まれます。

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

PHPは1994年に発信され、Rasmuslerdorfによって開発されました。もともとはウェブサイトの訪問者を追跡するために使用され、サーバー側のスクリプト言語に徐々に進化し、Web開発で広く使用されていました。 Pythonは、1980年代後半にGuidovan Rossumによって開発され、1991年に最初にリリースされました。コードの読みやすさとシンプルさを強調し、科学的コンピューティング、データ分析、その他の分野に適しています。

VSコードでは、次の手順を通じて端末でプログラムを実行できます。コードを準備し、統合端子を開き、コードディレクトリが端末作業ディレクトリと一致していることを確認します。プログラミング言語(pythonのpython your_file_name.pyなど)に従って実行コマンドを選択して、それが正常に実行されるかどうかを確認し、エラーを解決します。デバッガーを使用して、デバッグ効率を向上させます。
