如何解决如何根据用户输入参数从BigQuery获取结果
这是我以前制作api的延续,该api使用url参数,并将其传递给BigQuery,如果luid记录的orderid列中包含数据,则返回True。 How to check whether data exists in specific column on BigQuery with Flask?
我更改了sql,看来该sql在GCP控制台上运行良好,但是如您所见,如果从浏览器输入正确的参数,它将返回Flase({'f0_':0}))。我需要修复此SQL吗?
[URL:https://test-989898.df.r.appspot.com?luid=U77777]
The output of return str(row)
↓
Row((True,),{'f0_': 0})
The output of SQL with same luid above on console
↓
row | f0_
1 | true
SELECT EXISTS(SELECT 1
FROM `test-266110.conversion_log.conversion_log_2020*` as p
WHERE luid = "U77777" AND orderid != '' limit 1000)
并且我尝试了以下文章。用户输入参数在BigQuery中不可用? https://cloud.google.com/bigquery/docs/parameterized-queries
@app.route('/')
def get_request():
luid = request.args.get('luid') or ''
client = bigquery.Client()
query = """SELECT EXISTS(SELECT 1
FROM `test-266110.conversion_log.conversion_log_2020*` as p
WHERE @luid = p.luid AND orderid != '' limit 1000)"""
job_config = bigquery.QueryJobConfig(
query_parameters=[
bigquery.ScalarQueryParameter("luid","STRING",luid),]
)
query_job = client.query(query,job_config=job_config)
query_res = query_job.result()
for row in query_res:
return str(row)
↓
Row((True,{'f0_': 0})
我在这个问题上已经有一段时间了,欢迎提出任何想法。任何人都有好的解决方案??
from flask import Flask,request,jsonify
from google.cloud import bigquery
app = Flask(__name__)
@app.route('/')
def get_request():
luid = request.args.get('luid') or ''
client = bigquery.Client()
query = """SELECT EXISTS(SELECT 1
FROM `test-266110.conversion_log.conversion_log_2020*` as p
WHERE @luid = p.luid AND orderid != '' limit 1000)"""
job_config = bigquery.QueryJobConfig(
query_parameters=[
bigquery.ScalarQueryParameter("luid",job_config=job_config)
query_res = query_job.result()
# first_row = next(iter(query_job.result()))
for row in query_res:
return str(row)
#return jsonify({luid:query_res.total_rows})
"""
if query_res == :
return jsonify({luid: str(True)})
else:
return jsonify({luid: str(False)})
"""
if __name__ == "__main__":
app.run()
↓
Row((True,{'f0_': 0})
解决方法
您似乎已经解决了大多数问题,这只是使它们一起工作的问题。这是一个快速示例,可以帮助您处理BigQuery,并显示了使用公共数据集表编写查询模式的另一种方式。
TargetServerVersion
但是,那是为了确保您了解BigQuery的工作原理和查询费用。您似乎正在对一系列表(原始查询中的通配符表)进行点查找,这意味着您可能在做大量表扫描来满足此请求。
我只是想指出这一点,因此,如果您打算发出许多这样的请求,那么您对性能或成本都不会感到惊讶。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。