重音列名,内省和映射

时间:2014-07-24 20:42:08

标签: python unicode sqlalchemy

我想使用SQLAlchemy访问旧版MSSQL数据库。通过基本的模式检查,我已经可以列出我感兴趣的表的列。不幸的是,这些列名有时包含重音字母(例如“Magánszemély”,“LevelezésiCímIrányítószám”)。

我唯一的要求是能够查询此数据库。

我使用以下命令为您列出了一些数据库名称

def inspect_komplex_table():
    table = Table('D_Allomanylista_Komplex_V', meta, autoload=True, autoload_with=engine)
    return table

def get_columns():
    keys = inspect_komplex_table().columns.keys()
    keys.sort()
    txt = '\n'.join(keys)
    open('column_names.txt', 'w').write(txt.encode('utf8'))

这在column_names.txt文件中给出了一个(长)列表,其中包含以下行:

...
JutÉrvKezd
KEZDET
KTVSZAM
KamaraiTagszám
Képviselők
Lejarat
LevelezésiCímIrányítószám
LevelezésiCímUtca
LevelezésiCímVáros
...

我尝试创建一个没有重音列的基本映射

class BiztositasokModel(object):

    def __init__(self, UgyfKod):
        self.ugyfelkod = UgyfKod

其中UgyfKod是内省的一列,但是

mapper(BiztositasokModel, inspect_komplex_table())

UnicodeEncodeError

失败

有人可以告诉我如何处理这样的数据库吗?

1 个答案:

答案 0 :(得分:0)

我设法找到了两个答案,一个使用声明性语法,另一个使用经典映射。

两者都实现了一种将映射列的默认命名方案更改为Python对象属性的方法。

经典的映射答案是:SQLAlchemy mapping table with non-ascii columns to class

使用声明性语法的答案:http://docs.sqlalchemy.org/en/latest/orm/mapper_config.html#automating-column-naming-schemes-from-reflected-tables

相关问题