如何在SQLAlchemy ORM中复制此SQL

时间:2019-01-13 19:17:51

标签: python mysql sqlalchemy gis

我需要在SQLAlchemy中复制以下SQL语句,我使用ORM,尽管我可以仅使用原始引擎来运行SQL,但是然后在结果中失去面向对象的优点。

SELECT *, 
  (6371 * acos(cos(radians(50.4)) * cos(radians(latitude)) * cos(radians(longitude) - radians(-4.15)) + sin(radians(50.4)) * sin(radians(latitude)))) distance 
FROM mapobject 
HAVING distance < 150
ORDER BY distance;

1 个答案:

答案 0 :(得分:0)

最后,我承认,直接在会话内部使用引擎并失去针对该查询的ORM优势,因此容易得多。

    sql = text('SELECT *, (6371 *acos(cos( radians( %s ) ) * cos( radians( `latitude` ) ) * cos(radians( `longitude` ) - radians( %s )) + sin(radians(%s)) * sin(radians(`latitude`)))) `distance` FROM `mapobject` JOIN user ON mapobject.created_by = user.id WHERE deleted=0 HAVING `distance` < %s ORDER BY `distance`;' % (latitude, longitude, latitude, distance))
    map_objects = g.db.connection().execute(sql)
    humanised_map_objects = []
    for map_object in map_objects:
        tags = g.db.query(MapObjectTag).filter(MapObjectTag.map_object_id == map_object[0]).all()
        text_tags = []
        for tag in tags:
            text_tags.append(tag.tag)

        map_object_humanised = {'id': map_object[0],
                                'object_type': map_object[1],
                                'longitude': map_object[3],
                                'latitude': map_object[2],
                                'description': map_object[6],
                                'created_at': map_object[5].isoformat(),
                                'created_by': map_object[9],
                                'tags': text_tags}
        humanised_map_objects.append(map_object_humanised)

无论如何,如果有人有更好的方法可以做到这一点,并且仍然有ORM优势,请告诉我。