【发布时间】:2014-06-06 08:06:08
【问题描述】:
我似乎无法克服以下错误:
Traceback (most recent call last):
File "datascraper.py", line 352, in <module>
URL))
sqlite3.OperationalError: near "WHERE": syntax error
它来自以下代码(标记为第 352 行):
Table = someSQLtable //Has columns (providername, [other columns], providerlink)
SQLDatabase = sqlite3.connect(someSQLDatabase.db)
DBControl = cursor(SQLDatabase)
Name = 'somestring'
URL = 'http://www.someurl.com/stuff/'
[...] # Random other lines
DBControl.execute('''INSERT INTO '''+Table+''' (providername, providerlink)
VALUES (?, ?) WHERE NOT EXISTS (
SELECT * FROM '''+Table+'''
WHERE '''+Table+'''.providerlink = ?
);
352) ''', (Name, URL, URL))
作为参考,包裹在 Python 中的 SQL 命令应如下所示:
INSERT INTO someSQLtable (providername, providerlink)
VALUES ('somestring', 'http://www.someurl.com/stuff/')
WHERE NOT EXISTS (
SELECT * FROM someSQLtable
WHERE someSQLtable.providerlink = 'http://www.someurl.com/stuff/')
我的目标是检查表是否已包含相关条目,方法是检查新检索到的表链接(唯一)是否存在,如果不存在则写入表。
使用空格显示第 352 行的最后一个 URL 出现异常。
我已经尝试将输入修改为另一个字符串以查看是否可行,将代码更改为使用 Python 的字符串操作(太可怕了!),然后喝了一杯。到目前为止似乎没有任何效果。
【问题讨论】: