6

これは私のPythonコードです:

 cx=sqlalchemy.create_engine(u"mysql://username:password@ipaddress/database?charset=utf8")

 metadata=sqlalchemy.MetaData(cx)
 orm_obj=sqlalchemy.Table(u'I_POI',metadata,autoload=True)


 sql=orm_obj.select(u'poi_id,poi_name').where(u'poi_id>1 and poi_id>0').limit(3).offset(0)

 resultz=sql.execute()
 for i in resultz:
     print i

[DB] I_POIテーブル:poi_id、poi_name、poi_data1、poi_data2 ...... poi_data10

既存のデータベースで実行しますが、「select()」は機能しません。それでも合計列が返されます。
一部の列のみを取得したいので、助けてください。

4

2 に答える 2

8

これが私のために働くコードです:

from sqlalchemy import select
from sqlalchemy.sql import and_

results = select([orm_obj.c.poi_id, orm_obj.c.poi_name])\
    .where(and_(orm_obj.c.id > 1, orm_obj.c.id < 100)).execute()
for id, name in results:
    print id, name
于 2012-08-12T01:38:54.447 に答える
0

select代わりに汎用を使用してくださいTable.select

stmt = select([orm_obj.c.poi_id, orm_obj.c.poi_name]).\
where(and_(orm_obj.c.poi_id > 1, orm_obj.c.poi_id < 100)).\
limit(3)
result = conn.execute(stmt) 
于 2018-07-10T12:47:08.077 に答える