0

sqlalchemy のリフレクト機能を使用しようとしていますが、問題が発生しています。

これは、反映しようとしている mysql テーブルです

| Country | CREATE TABLE `Country` (
  `Code` varchar(8) NOT NULL,
  `Country` varchar(64) NOT NULL,
  `IsValid` varchar(1) DEFAULT 'Y',
  PRIMARY KEY (`Code`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |

コードの反映 (sch.py​​)。

from sqlalchemy.ext.declarative import declarative_base
import sqlalchemy
import eng

#Base = sqlalchemy.ext.declarative.declarative_base()
Base = declarative_base()

country = Table('Country',eng.Meta,autoload=True)
class Country(Base):    
    __tablename__ = country
    __mapper_args = {
        'primary_key' : [country.c.Code]
    }

eng.py

import sqlalchemy
import sqlalchemy.orm

eng = sqlalchemy.create_engine('mysql://user:pass@host/db',echo=True)

Meta = sqlalchemy.MetaData()
Meta.bind = eng

sesDec = sqlalchemy.orm.sessionmaker(bind=eng)

import schエラーが発生したとき。

import sqlalchemy
from sch import Country
import eng

ses = eng.sesDec()

res = ses.query(Country.Code.label('Code'),Country.Country.label('Country'))

for rec in res.filter(Country.IsValid == 'Y').filter(Country.Code.like('A%')).order_by(Country.Code).all():
    print rec

エラー(スタックトレースの下部)

  File "/pythonlib/lib64/python2.4/site-packages/sqlalchemy/sql/expression.py", line 4198, in description
    return self.name.encode('ascii', 'backslashreplace')
AttributeError: 'Table' object has no attribute 'encode
4

1 に答える 1

2
class Country(Base):    
    __tablename__ = country

ということ__table__ = countryですか?

于 2012-09-24T06:54:19.267 に答える