python- sqlite3.OperationalError:“ <”附近:语法错误 - python

我正在使用python 3.6。当我尝试实现此功能时,在以下行:cursor = conn.execute(cmd)
标题出现错误,有人可以帮我吗?万分感谢。
编辑:我已经找到了解决方案,只需将str(id)编辑为str(Id)

def getProfile(id):
    conn=sqlite3.connect("FaceBase.db")
    cmd="SELECT * FROM People WHERE ID=" +str(id)
    cursor=conn.execute(cmd)
    profile=None
    for row in cursor:
       profile=row
    conn.close()
    return profile

参考方案

查询的错误是,如果参数是字符串,则不会在cmd内包括引号。应该是这样的:

cmd="SELECT * FROM People WHERE ID='{}'".format(str(id))

正如@Aaron_ab在评论中提到的。切勿使用这种SQL查询,因为恶意用户可以执行SQL注入。例如,如果他将其放置为ID 1' OR 1=1 /*,它将返回表的所有行。

始终尝试使用禁止用户伪造自己的SQL语句的预准备语句。一个例子:

cmd="SELECT * FROM People WHERE ID=%s"
curs.execute(cmd, (str(id),))

“ python setup.py egg_info”失败,错误代码为1。如何解决此问题 - python

我该如何解决。我找不到任何带有“ Temp \ pip-install-7utykvpt \ polyglot”的目录C:\Windows\system32>pip install polyglot Collecting polyglot Using cached https://files.pythonhosted.org/packages/e7/9…

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

Python:集群作业管理 - python

我在具有两个阶段的计算群集(Slurm)上运行python脚本,它们是顺序的。我编写了两个python脚本,一个用于阶段1,另一个用于阶段2。每天早上,我检查所有第1阶段的工作是否都以视觉方式完成。只有这样,我才开始第二阶段。通过在单个python脚本中组合所有阶段和作业管理,是否有一种更优雅/自动化的方法?我如何知道工作是否完成?工作流程类似于以下内容:w…

Python:传递记录器是个好主意吗? - python

我的Web服务器的API日志如下:started started succeeded failed 那是同时收到的两个请求。很难说哪一个成功或失败。为了彼此分离请求,我为每个请求创建了一个随机数,并将其用作记录器的名称logger = logging.getLogger(random_number) 日志变成[111] started [222] start…

Python-Excel导出 - python

我有以下代码:import pandas as pd import requests from bs4 import BeautifulSoup res = requests.get("https://www.bankier.pl/gielda/notowania/akcje") soup = BeautifulSoup(res.cont…