首页 > 解决方案 > 如何在 SQLAlchemy 的原始 JOIN 查询中正确选择重复的字段名称

问题描述

我想在 SQLAlchcemy 中使用 Connection.execute() 运行原始 MySQL JOIN 查询。但是,我无法获取具有相同名称的任何两个字段/列的数据。

我的模型:

class Client(db.Model):
    id = db.Column(db.Integer, primary_key=True, autoincrement= True)
    client_name = db.Column(db.String(80), nullable=False)
    email = db.Column(db.String(120), nullable=False)

class User(db.Model):
    __table_args__ = {'mysql_engine': 'InnoDB', 'mysql_charset': 'utf8', 'mysql_collate': 'utf8_general_ci'}
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    username = db.Column(db.String(80), nullable=False)
    email = db.Column(db.String(120), nullable=False)
    client_id = db.Column('client_id', db.Integer, nullable=True, index=True)

正如您在两个模型中看到的那样,我有一个名为id

然后我有这个功能

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://my_user:password@localhost/my_db'
db = SQLAlchemy(app)
conn = db.engine.connect()
sql_statement = """SELECT * FROM User u JOIN Client c ON u.client_id = c.id"""
info = conn.execute(sql_statement)
for row in info:
   print(row)
   row = dict(row)
   print(row)

当我遍历执行结果时,我希望返回包含两个字段的记录u.idc.id但是我只得到一个名称为 id 的字段(甚至不是 u.id 或 c.id)。

我都试过了SELECT u.*, c.*SELECT u.id , c.id但没有奏效。

第一次打印(在转换为 dict 之前)打印具有两个 id 的所有字段的值,但在我将其转换为 dict 后它不再工作,在我的用例中,我必须将其转换为 dict。

如何在不必AS在查询中使用的情况下获得预期的行为?

注意:如果我使用SELECT u.* AS u_id, c.id AS c_id它可以正常工作,但我正在寻找另一种不使用AS.

标签: pythonsqlalchemyflask-sqlalchemy

解决方案


我为这个问题找到的唯一解决方法是执行以下操作:

sql_statement = """SELECT u.id AS `u.id`, c.id AS `c.id` FROM User u JOIN Client c ON u.client_id = c.id"""

这不是解决此问题的方法,而只是我遵循的解决方法,但仍然不太满意!


推荐阅读