码迷,mamicode.com
首页 > 数据库 > 详细

python_way day13 sqlalchemy

时间:2016-08-03 01:29:31      阅读:247      评论:0      收藏:0      [点我收藏+]

标签:

sqlalchemy

一对多

多对多

 


1、一对多

 

一、#创建表结构
class Host(Base):  #所有的子类都继承这个基类
    #创建表结构
    __tablename__ = hosts
    id = Column(Integer, primary_key=True,autoincrement=True) 
    hostname = Column(String(64),unique=True,nullable=False)     
    group_id = Column(Integer,ForeignKey(groups.id))   #创建外面hosts中的group_id关联到work_group的id
    group = relationship("Group")   #要写大写的实例名字通过映射的关系 , 能在hosts表中查询到外键表中的其他value
  
def __repr__(self):
        return "<id = %s,jump_user_name=%s>" % (self.id, self.username)
 class Group(Base): __tablename__= groups 
    id
= Column(Integer,primary_key=True) #自动自增,主键  
    
name = Column(String(64),unique=True,nullable=False)

Base.metadata.create_all(engine)
#执行上面的sql
图示: group
1 web 
 
2 db host hostname   

  外键group_id
1   nginx        1
2   mysql       2

这时候我们把host的group_id 和 group.id 做了外键关联
意思就是说我必须有group组,在能创建host组,或者说我们也可以先把host的这是为可以为空,这样就可以先填写host这涨表了

二、#插入数据
第一种插入数据的方法
1、我们可以直接插入host主机
h1 = Host(hostname = "nginx")
h2 = Host(hostname = "mysql")
session.add_all([h1,h2])
session.commit()
2、然后我们再插入group数据

g1 = Group(name = ‘web‘)
g2 = Group(name = ‘db‘)

session.add_all([g1,g2])
session.commit()

3、再做host和group关联(就是把host的group_id 改下)
g1 = session.query(Group).filter(Group.name == "web").first()      #找出g1的对象
h1 = session.query(Host).filter(Host.hostname==‘nginx‘).update({"group_id":g1.id})
session.commit()

#插入数据时也可以以主动指定外键的值,但是不要超过被关联的键的范围就可以
h1 = Host(hostname = "nginx",group_id = 1)
h2 = Host(hostname = "mysql",group_id = 2)
h3 = Host(hostname = "origer",group_id = 3)  这样就报错了



第二种插入数据的方法
先把group表值插进去,然后再插入host表
SessionCls = sessionmaker(bind=engine)
session = SessionCls()


g1 = Group(name = ‘web‘) #先插入group表
g2 = Group(name = ‘db‘)
session.add_all([g1,g2])
#
gw = session.query(Group).filter(Group.name == ‘web‘).first() #不用提交g1就可以在内存中查询到group中对应的数据,
gb = session.query(Group).filter(Group.name == ‘db‘).first()
h1 = Host(hostname = "nginx",group_id = gw.id)            #直接复制给h1使用
h2 = Host(hostname = "mysql",group_id = gb.id)
session.add_all([h1,h2])
session.commit()
三、查询

1、all 和 first
all()
gw = session.query(Group).all()
print(gw)
[<__main__.Group object at 0x0000003438C3F0F0>, <__main__.Group object at 0x0000003438C3F160>] #拿到了跟Group有关的所有数据,是个列表
print(gw[0].name)   
db
print(gw[0].id)
2

first()
gw = session.query(Group).first()
print(gw)
<__main__.Group object at 0x000000C703531208> #这个就是获取匹配到的第一个对象
print(gw.name)
db
print(gw.id)
2

2、query()
query中是要查的表,里面放的是表的类名,这里也是有2中情况

query(class)
gw = session.query(Group).all()
print(gw)
[<__main__.Group object at 0x000000446E0C1080>, <__main__.Group object at 0x000000446E0C10F0>] #这样知道的是所有的类对象,是个列表

query(class.args)
gw = session.query(Group.name).all()
print(gw)
[(‘db‘,), (‘web‘,)]

3、连表查询
SessionCls = sessionmaker(bind=engine)
session = SessionCls()


a、join : inner join
gw = session.query(Group).join(Host).all()
print(gw)
[<__main__.Group object at 0x0000002B1B345860>]
 
b、isouter=True : lelf join 
gw = session.query(Host).join(Group,isouter=True).all()
print(gw)
[hostanme : nginx  -  group_id = 1, hostanme : mysql  -  group_id = 1]

+----+----------+----------+------+------+
| id | hostname | group_id | id | name   |
+----+----------+----------+------+------+
| 1 | nginx    | 1     | 1   | web  |
| 2 | mysql    | 1     | 1   | web  |
+----+----------+----------+------+------+

上图发现,我们获取到的只是host表里的内容,并没有group中的内容

 

  c、我如果我们想要把host表中和gorup中的内容都获取到

gw = session.query(Host,Group).join(Group,isouter=True).all()
print(gw)
[(hostanme : nginx  -  group_id = 1, <__main__.Group object at 0x000000B3C53140B8>), (hostanme : mysql  -  group_id = 1, <__main__.Group object at 0x000000B3C53140B8>)]

d、我们想要拿到准确的内容,不要对象怎么做?
gw = session.query(Host.hostname,Group.name).join(Group,isouter=True).all()
print(gw)
[(‘nginx‘, ‘web‘), (‘mysql‘, ‘web‘)]

 

 

自定义查询返回值:

class JumpUser(Base):
    __tablename__ = jump_user
    id = Column(Integer, primary_key=True, autoincrement=True)
    username = Column(Integer,unique=True,nullable=False)
    passwd = Column(Integer,nullable=False)
    groups = relationship("Group",secondary=lambda : JumpUser_2_Group.__table__,backref=jumpuser_list)
    host_list = relationship("HostUser", secondary=lambda: JumpUser_2_HostUser.__table__, backref=jumpuser_list)
    def __repr__(self):
        return "<id = %s,jump_user_name=%s>" % (self.id, self.username)

repr中我们使用什么做返回值,在查询时就返回什么

 

  

 

python_way day13 sqlalchemy

标签:

原文地址:http://www.cnblogs.com/python-way/p/5731290.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!