gpt4 book ai didi

python - SQLAlchemy 在提交时自动将 str 转换为 unicode

转载 作者:太空狗 更新时间:2023-10-30 01:42:26 34 4
gpt4 key购买 nike

当使用 SQLAlchemy 将一个对象插入数据库时​​,它所有对应于 String() 列的属性都会自动从 转换为 。有没有办法防止这种行为?

代码如下:

from sqlalchemy import create_engine, Table, Column, Integer, String, MetaData
from sqlalchemy.orm import mapper, sessionmaker

engine = create_engine('sqlite:///:memory:', echo=False)
metadata = MetaData()

table = Table('projects', metadata,
Column('id', Integer, primary_key=True),
Column('name', String(50))
)

class Project(object):
def __init__(self, name):
self.name = name

mapper(Project, table)
metadata.create_all(engine)

session = sessionmaker(bind=engine)()

project = Project("Lorem ipsum")

print(type(project.name))

session.add(project)
session.commit()

print(type(project.name))

这是输出:

<type 'str'>
<type 'unicode'>

我知道我可能应该只使用 unicode,但这将涉及挖掘一些第三方代码,而且我还没有 Python 技能:)

最佳答案

实际上,有一种方法可以做到这一点。创建引擎后执行这行代码:

engine.raw_connection().connection.text_factory = str

关于python - SQLAlchemy 在提交时自动将 str 转换为 unicode,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3033741/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com