2012-01-31 43 views
2

我先从SQLAlchemy的,我试图让我的最后插入(鸣叫),但我只得到SQL查询:变换结果session.query到对象

conf = readConf("../utils/conf.yaml") 
schema = conf['bdd']['type'] + '://' + conf['bdd']['user'] + ':' + conf['bdd']['password'] + '@' + conf['bdd']['host'] + '/' + conf['bdd']['db'] + '?charset=utf8' 

engine = create_engine(schema, echo=True) 

Base = getBase() 
Base.metadata.create_all(engine) 

Session = sessionmaker(bind=engine) 
session = Session() 
tq = session.query(Tweet).group_by(Tweet.tweet_id_uniq).filter(func.max(Tweet.tweet_id_uniq) == Tweet.tweet_id_uniq) 
# tweet_id_uniq is a BIGINT autoincrement, so the highest value is the last Tweet. 
print tq 

打印结果的SQL查询(包为易读性):

SELECT tweets.tweet_id AS tweets_tweet_id, 
     tweets.tweet_id_uniq AS tweets_tweet_id_uniq, 
     tweets.user_id AS tweets_user_id, 
     tweets.user_id_uniq AS tweets_user_id_uniq, 
     tweets.tweet_text AS tweets_tweet_text, 
     tweets.created_at AS tweets_created_at, 
     tweets.in_reply_to AS tweets_in_reply_to, 
     tweets.geo_lat AS tweets_geo_lat, 
     tweets.geo_long AS tweets_geo_long, 
     tweets.screen_name AS tweets_screen_name, 
     tweets.name AS tweets_name, 
     tweets.profile_image_url AS tweets_profile_image_url, 
     tweets.source AS tweets_source 
FROM tweets 
WHERE max(tweets.tweet_id_uniq) = tweets.tweet_id_uniq 
GROUP BY tweets.tweet_id_uniq 

为什么我不检索Tweet?

编辑:如果我加入。一()或.fisrt()或。所有(),我得到这个错误:

2012-01-31 16:05:37,644 INFO sqlalchemy.engine.base.Engine BEGIN (implicit) 
2012-01-31 16:05:37,645 INFO sqlalchemy.engine.base.Engine SELECT tweets.tweet_id AS tweets_tweet_id, tweets.tweet_id_uniq AS tweets_tweet_id_uniq, tweets.user_id AS tweets_user_id, tweets.user_id_uniq AS tweets_user_id_uniq, tweets.tweet_text AS tweets_tweet_text, tweets.created_at AS tweets_created_at, tweets.in_reply_to AS tweets_in_reply_to, tweets.geo_lat AS tweets_geo_lat, tweets.geo_long AS tweets_geo_long, tweets.screen_name AS tweets_screen_name, tweets.name AS tweets_name, tweets.profile_image_url AS tweets_profile_image_url, tweets.source AS tweets_source 
FROM tweets 
WHERE max(tweets.tweet_id_uniq) = tweets.tweet_id_uniq 
2012-01-31 16:05:37,645 INFO sqlalchemy.engine.base.Engine() 
... 
File "/usr/local/lib/python2.6/dist-packages/SQLAlchemy-0.7.3-py2.6-linux-i686.egg/sqlalchemy/engine/default.py", line 330, in do_execute 
cursor.execute(statement, parameters) 
File "/usr/lib/pymodules/python2.6/MySQLdb/cursors.py", line 166, in execute 
self.errorhandler(self, exc, value) 
File "/usr/lib/pymodules/python2.6/MySQLdb/connections.py", line 35, in defaulterrorhandler 
raise errorclass, errorvalue 
sqlalchemy.exc.ProgrammingError: (ProgrammingError) (1111, 'Invalid use of group function') 'SELECT tweets.tweet_id AS tweets_tweet_id, tweets.tweet_id_uniq AS tweets_tweet_id_uniq, tweets.user_id AS tweets_user_id, tweets.user_id_uniq AS tweets_user_id_uniq, tweets.tweet_text AS tweets_tweet_text, tweets.created_at AS tweets_created_at, tweets.in_reply_to AS tweets_in_reply_to, tweets.geo_lat AS tweets_geo_lat, tweets.geo_long AS tweets_geo_long, tweets.screen_name AS tweets_screen_name, tweets.name AS tweets_name, tweets.profile_image_url AS tweets_profile_image_url, tweets.source AS tweets_source \nFROM tweets \nWHERE max(tweets.tweet_id_uniq) = tweets.tweet_id_uniq GROUP BY tweets.tweet_id_uniq'() 

回答

2

您试图匹配最大的值,然后对其进行分组。该值是独一无二的。所以你可能只需点一下就可以得到一个。

tq = session.query(Tweet).order_by(desc(Tweet.tweet_id_uniq)).first() 

tq现在是您的Tweet对象的最大ID。

顺便说一句,问题是您的结果查询是不正确的SQL。如果不重新包括表(这可能不是您想要做的)或使用子查询(也很尴尬),您无法将最大值与同一表中的列进行匹配。

+0

它的工作原理。谢谢你的解释。你的解决方案确实更加优雅。 – Yohann 2012-01-31 20:29:38

1

试试这个: session.query(Tweet).group_by(Tweet.tweet_id_uniq).filter(func.max(Tweet.tweet_id_uniq) == Tweet.tweet_id_uniq).all()

first(),或one()

+0

在编辑中查看答案。 – Yohann 2012-01-31 15:02:03