0

我想通过flask-peewee运行以下查询,

merchant_name喜欢“海边%”

SELECT * 
FROM  `merchant_details` 
WHERE  `merchant_name` LIKE  'seaside%'

这是以下 URL 的返回 JSON,我需要过滤 merhcnat_name http://www.XXXXX.com/api/merchant_details/

http://www.XXXXX.com/api/merchant_details/?merchant_name__like=seaside(这不起作用)

{
  "meta": {
    "model": "merchant_details",
    "next": "",
    "page": 1,
    "previous": ""
  },
  "objects": [
    {
      "merchant_name": "Seaside Grill",
      "city": "Santa Monica ",
      "zipcode": "90401",
      "long": "-118.4884742",
      "phone": "3102399844",
      "state": "CA",
      "updated_on": "2013-11-07 01:14:42",
      "lat": "34.0189893",
      "street_1": "406 Broadway",
      "street_2": "1",
      "merchant_id": "1",
      "id": "2"
    },
{
  "merchant_name": "Jack n'  Jill's",
  "city": "Santa Monica",
  "zipcode": "90401",
  "long": "-118.4937635",
  "phone": "3109873733",
  "state": "CA",
  "updated_on": "2013-11-08 08:20:29",
  "lat": "34.0173215",
  "street_1": "510 Santa Monica Blvd",
  "street_2": "1",
  "merchant_id": "48",
  "id": "32"
}
  ]
}
4

2 回答 2

2

您应该像这样对 url 进行编码:

?merchant_name__like=seaside%25

您可以通过urllib.urlencode({'merchant_name__like': 'seaside%'}),在 sql中获取编码的查询字符串。?merchant_name__like=seasideLIKE seaside

于 2013-12-23T10:41:51.143 回答
-1

您可以使用sqlalchemy-elasticquery来进行这样的搜索:

?filters={ "merchant_nameseaside" : {"like" : "%seaside%"} }

和另一个自定义过滤器。

于 2015-03-17T18:50:27.197 回答