sqlalchemy多对多查询
# coding:utf-8
from sqlalchemy import create_engine, Column, String, Integer, ForeignKey, Table
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker, relationship DB_URI = "mysql+pymysql://root:123123sdt@127.0.0.1:3306/xiachufang"
engine = create_engine(DB_URI)
Base = declarative_base(engine)
session = sessionmaker(engine)() # 创建一个多对多的关系(老师与学生的关系)需要创建一个中间表
# 创建一个中间表
teacher_classes = Table(
"teacher_classes",
Base.metadata,
Column("teacher_id", Integer, ForeignKey("teacher.id"), nullable=False, primary_key=True),
Column("classes_id", Integer, ForeignKey("classes.id"), nullable=False, primary_key=True)
) # 创建老师的映射
class Teacher(Base):
__tablename__ = "teacher"
id = Column(Integer, primary_key=True, autoincrement=True)
teacher_name = Column(String(100))
classes = relationship("Classes", secondary=teacher_classes) def __repr__(self):
return "<Teacher id='%s' teacher_name='%s'>" % (self.id, self.teacher_name) # 创建学生的映射
class Classes(Base):
__tablename__ = "classes"
id = Column(Integer, primary_key=True, autoincrement=True)
classes_name = Column(String(100))
teacher = relationship("Teacher", secondary=teacher_classes) def __repr__(self):
return "<Classes id='%s' classes_name='%s'>" % (self.id, self.classes_name) #
# # 创建数据库
# Base.metadata.create_all() # # 创建两个老师
# teacher1 = Teacher(teacher_name='admin')
# teacher2 = Teacher(teacher_name='grunt')
# teacher3 = Teacher(teacher_name='shuihen') # # 创建两门课程
# classes1 = Classes(classes_name="java")
# classes2 = Classes(classes_name="python")
#
# # 添加数据
# teacher1.classes = [classes1,classes2]
# teacher2.classes = [classes1,classes2]
# teacher3.classes = [classes1]
# session.add(teacher1)
# session.add(teacher2)
# session.add(teacher3)
# session.commit() # # 查询下数据(根据老师查询课程)
# # teacher = session.query(Teacher).first()
# # print teacher.classes
#
# # 根据课程查询老师
# classes = session.query(Classes).get(1)
# print classes.teacher
#
# # 根据老师查询课程
# teacher = session.query(Teacher).get(3)
# print teacher.classes
sqlalchemy多对多查询的更多相关文章
- flask的orm框架(SQLAlchemy)-一对多查询以及多对多查询
		一对多,多对多是什么? 一对多.例如,班级与学生,一个班级对应多个学生,或者多个学生对应一个班级. 多对多.例如,学生与课程,可以有多个学生修同一门课,同时,一门课也有很多学生. 一对多查询 如果一个 ... 
- 数据库开发-Django ORM的多对多查询
		数据库开发-Django ORM的多对多查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.联合主键问题 CREATE TABLE `employees` ( `emp_no` ... 
- 22Mybatis_订单商品数据模型_多对多查询以及对多对多查询的总结
		之前讲了一对一,一对多查询,这篇文章讲的是多对多. 先给出需求:查询用户及用户购买商品信息. 我们由之前的文章知道,这个需求是多对多的. 还是那个终止我们的mybatis所做的不管是之前的一对一还是一 ... 
- mybatis(一、原理,一对多,多对一查询)
		MyBatis框架及原理分析 MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转换 ... 
- SpringBoot使用Mybatis注解进行一对多和多对多查询(2)
		SpringBoot使用Mybatis注解进行一对多和多对多查询 GitHub的完整示例项目地址kingboy-springboot-data 一.模拟的业务查询 系统中的用户user都有唯一对应的地 ... 
- MyBatis多对多查询
		-------------------siwuxie095 MyBatis 多对多查询 以订单和商品为例,即 一个订单可 ... 
- mybatis由浅入深day02_4多对多查询_多对多查询总结
		4 多对多查询 4.1 需求(查询用户及用户购买商品信息) 查询用户及用户购买商品信息. 4.2 sql语句 查询主表是:用户表 关联表:由于用户和商品没有直接关联,通过订单和订单明细进行关联,所以关 ... 
- 基于对象的跨表查询,多对多查询,多对多操作,聚合查询和分组查询,F查询和Q 查询
		基于对象的跨表查询 一对多查询(班级表和学生表) 表结构创建 class Class(models.Model): id = models.AutoField(primary_key=True) cn ... 
- mybatis学习记录六——一对一、一对多和多对多查询
		9 订单商品数据模型 9.1 数据模型分析思路 1.每张表记录的数据内容 分模块对每张表记录的内容进行熟悉,相当 于你学习系统 需求(功能)的过程. 2.每张表重要的字段设置 非空 ... 
随机推荐
- 【EatBook】-NO.3.EatBook.3.JavaArchitecture.2.001-《架构探险:从零开始写Java Web框架》-
			1.0.0 Summary Tittle:[EatBook]-NO.3.EatBook.3.JavaArchitecture.2.001-<架构探险:从零开始写Java Web框架>- S ... 
- [LeetCode] 584. Find Customer Referee_Easy tag: SQL
			Given a table customer holding customers information and the referee. +------+------+-----------+ | ... 
- 用python.twisted.logfile每天记录日志,并用不记录stdout中的内容
			#导入的头 from twisted.python import logfrom twisted.python.logfile import * #开始记录,输入日志名和存放的路径,setStdout ... 
- Hibernate.编写xml文件无自动提示信息
			Hibernate.编写xml文件无自动提示信息 注意: 配置 xxxx.hbm.xml 文件的自动提示.和配置 hibernate.cfg.xml 文件的提示,操作步骤是一样的.只是复制的文件内容. ... 
- SQL 跟据出生日期求年龄
			最近做项目时遇到一个问题. 跟据人员的生日与当前日期进行比较求出该人员实际年龄.这个看上去比较简单的问题,其实不细心去看也会有很多问题. 先看第一种: 一张人员信息表里有一人生日(Birthday)列 ... 
- c#之如何正确地实现IDisposable接口
			见实例: public class TestClass : IDisposable { //供程序员显式调用的Dispose方法 public void Dispose() { //调用带参数的Dis ... 
- latex 公式 和排版
			http://bbs.chinatex.org/forum.php?mod=viewthread&tid=7423 http://blog.sina.com.cn/s/blog_5e16f17 ... 
- Rigid Frameworks (画图二分图规律 + DP + 数学组合容斥)
			题意:方格n*m,然后对于每一个格子有3种画法1左对角线2右对角线3不画,求让图形稳定的画法有多少种? 思路:通过手画二分图可以发现当二分图联通时改图满足条件,然后我们对于一个dp[n][m]可以利用 ... 
- Python scrapy - Login Authenication Issue
			https://stackoverflow.com/questions/37841409/python-scrapy-login-authenication-issue from scrapy.cra ... 
- Lua数据类型
			[1]Lua数据类型 Lua语言共有8种基本类型 [1] nil 空.最简单,有且仅有值nil,表示一个无效值(在条件表达式中相当于false) [2] boolean 布尔.包含两个值:false和 ... 
