0
我觉得这应该很简单,但我无法找到它正在完成的一个例子。sqlalchemy 0.6遗留数据库访问?
作为一个例子,我有以下现有表:
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的方式。我跟着文件的数据库反射的东西,并得到了这么多:
import sqlalchemy
from sqlalchemy import Table, Column, MetaData, create_engine
from sqlalchemy.orm import sessionmaker
engine = create_engine('mysql://user:[email protected]/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的东西。这可能不需要重写类来模拟整个表结构?如果没有,有人可以告诉我在这个例子中我该怎么做?
有人可以设置我正确的路径让映射器的东西工作?