V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
paloalto
V2EX  ›  问与答

请教GQL中如何随机排序?

  •  
  •   paloalto · 2010-11-14 13:12:07 +08:00 · 4542 次点击
    这是一个创建于 5153 天前的主题,其中的信息可能已经有所发展或是发生改变。
    我不是程序员,SQL语句也没接触过。

    尝试写了一点:
    q999 = db.GqlQuery("SELECT * FROM Member ORDER BY created RAND LIMIT 24")

    结果报错了,说语句不对,查文档,说是:

    “可选的 ORDER BY 子句指示应按照指定属性进行排序,以升序 (ASC) 或降序 (DESC) 返回结果。如果未指定方向,其默认为 ASC。ORDER BY 子句可以用逗号分隔列表的形式指定多个排序顺序,从左到右进行评估。 ”

    ——这意思是不是说无法实现直接用GQL语句随机排序?

    问朋友,他们说可以不用GQL语句来排序,而是只用GQL把数据都读出来,然后用程序进行排序。但是我不知道程序该怎么写。

    请指教。谢谢
    5 条回复    1970-01-01 08:00:00 +08:00
    billychow
        1
    billychow  
       2010-11-14 14:49:23 +08:00
    shuffle(collection)
    Livid
        2
    Livid  
    MOD
       2010-11-14 16:21:56 +08:00
    GQL 本身没有这样的功能,需要在 py 里做随机。
    darasion
        3
    darasion  
       2010-11-14 17:59:44 +08:00
    嗯,如果是实现 稳定排序 我倒是有个办法。
    随机的话好像只能如一楼那样了。
    paloalto
        5
    paloalto  
    OP
       2010-11-14 19:21:11 +08:00
    THX
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5907 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 02:01 · PVG 10:01 · LAX 18:01 · JFK 21:01
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.