關係資料庫是建立在關係模型基礎上的資料庫,所以表格之間的關係在資料庫程式設計中特別重要。本節圍繞在SQLAlchemy中如何定義關係及如何使用關係進行查詢進行講解,使讀者能夠快速掌握SQLAlchemy的關係操作。
1、案例
設計3個實體表:班級表class、學生表student、老師表teacher和1個關係表:class_teacher。班級與學生為一對多關係,班級與老師為多對多關係。
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個表進行了定義,其中與關係定義相關的部分如下:
外鍵設定:在列的定義中,為Column傳入ForeignKey進行外鍵設定。
class_id=Column(Integer,ForeignKey('class.id'))
關係設定:透過relationship關鍵字在父模型中建立對字表的引用,例如Class模型中的關係設定如下:
students=relationship("Student",backref="calss")
其中的backref參數為可選參數,如果設定backref,則此語句同時設定了從父表對子表的參考。
一對多關係的使用:以後可以直接透過該students屬性來獲得相關班級中所有學生的資訊。如下代碼可以列印班級【三年二班】的所有學生資料。
class=session.query(Class).filter(Clss.name=="三年二班").first() for student in class_.students: print(student)
多對多關係的使用:透過關聯模型ClassTeacher實現,在其中分別設定模型Class和Teacher的外鍵,並且在父模型中設置相應的relationship實現。多對多關係也可以想像成一個關聯表,分別對兩個父表實現了多對一的關係。班級與老師之間為多對多的關係,如下代碼可以打印班級【三年二班】中所有老師的信息
class=session.query(Class).filter(Class.name=="三年二班").first() for class_teacher in class_.class_teachers: teacher=class_teacher.teacher print(teacher)上述代碼中class_teacher.teacher是在模型teacher中針對ClassTeacher定義的反向引用。
2、連接查詢
在實際開發中,有了關係就必不可少地會有多表連接查詢的需求。下面透過實際範例示範如果進行多表連接查詢。
在查詢語句中可以使用join關鍵字進行連接查詢,列印所有三年級學生的姓名:
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,)
如果需要將被連接表的內心同樣列印出來,則可以在query中指定多個表物件。
下面的語句在印出所有三年級學生姓名的同時,印出其所在班級的名字。
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,)
如果需要用除外鍵外的其他欄位作為連線條件,則需要開發者在join中自行設定。下面印出所有班級的address與學生的address相同的學生的姓名:
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中文網其他相關文章!

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

Python3.6環境下加載Pickle文件報錯:ModuleNotFoundError:Nomodulenamed...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

禪工作室 13.0.1
強大的PHP整合開發環境

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver CS6
視覺化網頁開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。