0

我觉得这应该很简单,但我找不到一个例子。

例如,我有以下现有表:

CREATE TABLE `source` (
  `source_id` tinyint(3) unsigned NOT NULL auto_increment,
  `name` varchar(40) default NULL,
  PRIMARY KEY  (`source_id`),
  UNIQUE KEY `source_name` (`name`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

CREATE TABLE `event` (
  `source_id` tinyint(3) unsigned NOT NULL default '0',
  `info` varchar(255) NOT NULL default '',
  `item` varchar(100) NOT NULL default '',
  PRIMARY KEY  (`source_id`,`info`,`item`),
  KEY `event_fkindex1` (`source_id`),
  CONSTRAINT `event_fk1` FOREIGN KEY (`source_id`) REFERENCES `source` (`source_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

我想使用 sqlalchemy 0.6 向事件表中添加很多行。我看过一些 sqlsoup 示例,但真的很讨厌它通过不断调用 db 对象来访问 db 的方式。我遵循了 db 反射的文档并做到了这一点:

import sqlalchemy
from sqlalchemy import Table, Column, MetaData, create_engine
from sqlalchemy.orm import sessionmaker
engine = create_engine('mysql://user:pass@server/db', echo=True)
metadata = MetaData()
source = Table('source', metadata, autoload=True, autoload_with=engine)
Session = sessionmaker(bind=engine)
session = Session()
session.query(source).first()

这会返回一个非常丑陋的对象。我真的想要 sqlalchemy ORM 的映射器功能,这样我就可以构造 Event 对象以插入数据库。

我查看了 sqlsoup 的东西:

from sqlalchemy.ext.sqlsoup import SqlSoup
db = SqlSoup(engine)
db.sources.all() #this kinda works out bet

但我不知道如何从这一点添加对象。我什至不确定这是我想要的,我希望能够遵循教程和 declarative_base 的东西。这是否可能无需重写一个类来对整个表结构进行建模?如果不是,有人可以告诉我在这个例子中我会怎么做吗?

有人可以让我找到正确的路径来让映射器工作吗?

4

1 回答 1

2

您可以将预定义/自动加载的表与 declarative_base 一起使用,方法是将其分配给 __table__ 属性。这些列是从表中提取的,但您仍然需要声明要使用的任何关系。

class Source(Base):
    __table__ = source

class Event(Base):
    __table__ = event
    source = relation(Source)

但是,如果您要插入大量行,那么绕过 ORM 并使用 executemany 将大大提高性能。您可以像这样使用执行许多:

conn = engine.connect()
conn.execute(event.insert(),[
    {'source_id': 1, 'info': 'xyz', 'item': 'foo'},
    {'source_id': 1, 'info': 'xyz', 'item': 'bar'},
    ...
])
于 2010-02-18T18:56:21.950 回答