【发布时间】:2012-02-15 10:04:10
【问题描述】:
我正在使用由第三方通过 sqlalchemy 创建的现有数据库。但是,我遇到了麻烦,因为表没有主键,更糟糕的是,它们的每一行都有重复的元素,所以我不能选择现有的列作为主键。这些表有两列:都有非唯一值。
我尝试按照http://www.blog.pythonlibrary.org/2010/09/10/sqlalchemy-connecting-to-pre-existing-databases/ 对表格进行猴子修补,但显然这不起作用(见下文)
我当前的代码是(MirnaTable 是我的映射类,基本上只是一个骨架,没有别的)
connection = create_engine("sqlite:///targets.sqlite")
metadata = MetaData(bind=connection)
db_table = Table("miranda", metadata,
Column("id", Integer, primary_key=True),
autoload=True)
mapper(MirnaTable, db_table)
Session = sessionmaker(connection)
session = Session()
然后我尝试例如发布
all_records = session.query(MirnaTable).all()
我得到了
sqlalchemy.exc.OperationalError: (OperationalError) no such column: miranda.id
u'SELECT miranda.gene_id AS miranda_gene_id, miranda."mature_miRNA" AS
"miranda_mature_miRNA", miranda.id AS miranda_id \nFROM miranda' ()
所以当然找不到 id 列。关于我做错了什么的任何想法?提前致谢。
编辑:根据要求,这是表中的一个示例(直接从 sqlite 检索):
gene mature_miRNA
---- -------------
80205 hsa-miR-200c
80205 hsa-miR-200c
9693 hsa-miR-200c
9693 hsa-miR-200c
9881 hsa-miR-200c
9710 hsa-miR-200c
9750 hsa-miR-200c
【问题讨论】:
-
能否请您发布带有示例数据的表格?
-
完成:您现在可以期待什么样的数据样本。
-
如果没有可以用作行标识的东西,ORM 将无法工作。考虑直接使用表而不将其映射到类。
标签: python sqlalchemy