采用python中SQLalchemy模块访问数据库库(二)

采用python中SQLalchemy模块访问数据库(二)

上一篇中提到,通过create_engine创建数据库引擎,并新建一个MetaData对象,MetaData对象收集了描述table对象等的元数据类,

将其与genine进行绑定,然后通过Table函数构造三张表,通过执行create_all()将表创建在数据库中,通过mapper实现表与Python类的映射。

对于已经存在于数据库中的表,同样可以通过传入参数 autoload=True 到Table函数,从而实现加载现有的表结构到MetaData对象中,

同样需要mapper实现其与定义好的python类映射。如:

users_table = Table('users', metadata, autoload=True)

mapper(user, users_table)

#autoload :默认为false,当数据库已经存在这个table会自动覆盖加载

#autolaod_with : 默认是false,是否自动加载引擎的字段结构

#reflect : 默认是false,是否体现源表结构

在此基础上,也可以通过判断获取的Metadata中字段个数是否大于0来却仍表是否存在,如

users_table = Table('users', metadata, autoload=True)

exists = len(users_table.columns) > 0

另外,Table构造函数中,还可以增加properties参数,它是一个字典,实现一对多的映射

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值