我想使用 SQLAlchemy 1.1.5 在 Postgresql 数据库中拥有一个 uuid 类型的主键 id,并使用 pg8000 适配器连接到数据库。我用的是与后端无关的 GUID 类型 recipe http://docs.sqlalchemy.org/en/rel_1_1/core/custom_types.html#backend-agnostic-guid-type来自 SQLAlchemy 文档。
当我想插入数据库时,出现以下错误
File ".../guid.py", line ???, in process_result_value
return uuid.UUID(value)
File "/usr/lib/python2.7/uuid.py", line 131, in __init__
hex = hex.replace('urn:', '').replace('uuid:', '')
AttributeError: 'UUID' object has no attribute 'replace'
我的模型看起来像这样
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String
from guid import GUID
import uuid
base = declarative_base()
class Item(base):
__tablename__ = 'item'
id = Column(GUID(), default=uuid.uuid4, nullable=False, unique=True, primary_key=True)
name = Column(String)
description = Column(String)
def __repr__(self):
return "<Item(name='%s', description='%s')>" % (self.name, self.description)
我的资源或控制器看起来像这样
data = req.params
item = Item(name=data['name'], description=data['description'])
self.session.add(item)
self.session.commit()