热门IT资讯网

Python 之 sqlalchemy 外键正反向关联查询

发表于:2024-11-24 作者:热门IT资讯网编辑
编辑最后更新 2024年11月24日,表内容:代码:#Author Kangimport sqlalchemyfrom sqlalchemy import create_enginefrom sqlalchemy.ext.declarat

表内容:

代码:

#Author Kangimport sqlalchemyfrom sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy import Column,Integer,String,ForeignKeyfrom sqlalchemy.orm import sessionmaker,relationship#创建对象的基类:Base = declarative_base()#定义User对象:class User(Base):    #表的名字:    __tablename__ = 'user'    #表的结构:    userid = Column(Integer,primary_key=True)    username = Column(String(20))    age = Column(Integer)    department = Column(String(20))    salary = relationship("Salary",backref="test")    #def __repr__(self):    #    return "userid:%s name:%s age:%s department:%s money:%s "%(self.userid,self.username,self.age,self.department,self.salary[0])#定义Salary对象:class Salary(Base):    #表的名字:    __tablename__ = 'salary'    #表的结构:    id = Column(Integer,primary_key=True)    userid = Column(Integer,ForeignKey("user.userid"))    month = Column(Integer)    money = Column(Integer)    def __repr__(self):        return "%s" % (self.money)#初始化数据库连接engine = create_engine("mysql+pymysql://kang:[email protected]/test",encoding="utf-8")#创建session类型DBSession = sessionmaker(bind=engine)#创建session对象session = DBSession()print("Salary表,通过backref反向查询User的姓名信息>>>>>>>>>>>>>>")e1 = session.query(Salary).filter_by(userid=3).first()print(e1.test.username,e1.money)print("user表,正向查询salary工资信息>>>>>>>>>>>>>>>>>>>>>>>>")res = session.query(User).filter_by(username='MingKang').first()print(res.username,res.salary[0])

结果:

Salary表,通过backref反向查询User的姓名信息>>>>>>>>>>>>>>MingKang 12000user表,正向查询salary工资信息>>>>>>>>>>>>>>>>>>>>>>>>MingKang 12000
0