现在的位置: 首页 > 综合 > 正文

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

2013年10月09日 ⁄ 综合 ⁄ 共 635字 ⁄ 字号 评论关闭

采用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参数,它是一个字典,实现一对多的映射

抱歉!评论已关闭.