这正是我收到的错误信息:
(1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1")
这是我的密码。你知道吗
def mysql_connect():
conn = MySQLdb.connect(host = "localhost",
user = "root",
passwd = "********",
db = "seomonster")
cursor = conn.cursor()
filename = 'tdnam_all_listings.csv'
filename2 = 'tdnam_all_listings2.csv'
filename3 = 'tdnam_all_listings3.csv'
try:
table_create = """CREATE TABLE sites (domainName CHAR(40),
itemID INT,auctionType CHAR(40),
timeLeft CHAR(40),
price CHAR(20),
bids INT,
domainAge INT,
traffic INT,
valuationPrice CHAR(40))"""
cursor.execute(table_create)
except Exception as e:
print e
try:
csv_data = csv.reader(file(filename))
for row in csv_data:
cursor.execute("""INSERT INTO sites(domainName,itemID,auctionType,timeLeft,price,bids,domainAge,traffic,valuationPrice)""")
except Exception as e2:
print e2
conn.commit()
cursor.close()
conn.close()
我完全不理解这个错误,尽管我假设它与我通过插入数据而使用的SQL语法有关?你知道吗
@伯尼 将我的代码更改为:
cursor.execute("""INSERT INTO sites(domainName,itemID,auctionType,timeLeft,price,bids,domainAge,traffic,valuationPrice) values (%s%s,%s,%s,%s,%s,%s,%s,%s);""")
现在得到这个错误:
(1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '%s%s,%s,%s,%s,%s,%s,%s,%s)' at line 1")
@VMai公司 我听从了你的建议,把代码改成:
for row in csv_data:
insert = """INSERT INTO sites (domainName,itemID,auctionType,timeLeft,price,bids,domainAge,traffic,valuationPrice) values (%s,%s,%s,%s,%s,%s,%s,%s,%s);"""
cursor.execute(insert,(row[0],row[1],row[2],row[3],row[4],row[5],row[6],row[7],row[8]))
我得到了一个很长的错误,我认为这与%s有关,有些列是整数,这就是我认为的原因。 错误:
Warning (from warnings module):
File "/var/www/seomonster/ZeroPain.py", line 109
cursor.execute(insert,(row[0],row[1],row[2],row[3],row[4],row[5],row[6],row[7],row[8]))
Warning: Incorrect integer value: ' ItemID' for column 'itemID' at row 1
Warning (from warnings module):
File "/var/www/seomonster/ZeroPain.py", line 109
cursor.execute(insert,(row[0],row[1],row[2],row[3],row[4],row[5],row[6],row[7],row[8]))
Warning: Incorrect integer value: ' Bids' for column 'bids' at row 1
Warning (from warnings module):
File "/var/www/seomonster/ZeroPain.py", line 109
cursor.execute(insert,(row[0],row[1],row[2],row[3],row[4],row[5],row[6],row[7],row[8]))
Warning: Incorrect integer value: ' Domain Age' for column 'domainAge' at row 1
Warning (from warnings module):
File "/var/www/seomonster/ZeroPain.py", line 109
cursor.execute(insert,(row[0],row[1],row[2],row[3],row[4],row[5],row[6],row[7],row[8]))
Warning: Incorrect integer value: ' Traffic' for column 'traffic' at row 1
Warning (from warnings module):
File "/var/www/seomonster/ZeroPain.py", line 109
cursor.execute(insert,(row[0],row[1],row[2],row[3],row[4],row[5],row[6],row[7],row[8]))
Warning: Data truncated for column 'domainName' at row 1
我假设您在第一个查询参数
%s
之后只缺少一个逗号,因为您有9个字段要填充,但最后只有8个参数。第一个和第二个%s
将被连接起来,因为它们之间缺少逗号。你知道吗第二,如注释中所述,将参数作为第二个参数传递给此函数。你知道吗
试试这个:
相关问题 更多 >
编程相关推荐