2

好的,所以我有这种模式:

class Posts(db.Model):
  rand1 = db.FloatProperty()
  #other models here

这个控制器:

class Random(webapp.RequestHandler):
  def get(self):    
      rand2 = random.random()
      posts_query = db.GqlQuery("SELECT * FROM Posts WHERE rand1 > :rand2 ORDER BY rand LIMIT 1")
      #Assigning values for Django templating
      template_values = {
          'posts_query': posts_query,
           #test purposes
          'rand2': rand2,
          }

      path = os.path.join(os.path.dirname(__file__), 'templates/random.html')
      self.response.out.write(template.render(path, template_values))

因此,当添加一个实体时,会生成一个随机浮点数(0-1),然后当我需要获取一个随机实体时,我希望能够只使用一个简单的 SELECT 查询。它错误:

BadArgumentError('Missing named arguments for bind, requires argument rand2',)

现在,如果我去,这可行:

posts_query = db.GqlQuery("SELECT * FROM Posts WHERE rand1 > 1 ORDER BY rand LIMIT 1")

很明显我的查询是错误的;如何在 where 语句中使用变量:S

4

1 回答 1

3

代替:

 "...WHERE rand1 > :rand2 ORDER BY rand LIMIT 1")

和:

  "...WHERE rand1 > :rand2 ORDER BY rand LIMIT 1", rand2=rand2)

或者

  "...WHERE rand1 > :1 ORDER BY rand LIMIT 1", rand2)

有关更多信息,请参阅:“ Gql 查询类

有趣的是,我大约 2 小时前才知道这一点:P

于 2009-08-27T03:40:41.317 回答