我试图通过写入管道将数据存储到MySQL中,但它发生了:
_mysql_exceptions.ProgrammingError: (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 'desc,pic)values ('xe4\xbe\x9b\xe5\xba.......' at line 1")
这是我的代码:
def __init__(self):
#self.file = codecs.open('tutorial_data.json','wb',encoding='utf-8')
self.dbpool = adbapi.ConnectionPool('MySQLdb',
host = 'localhost',
port = 3306,
db = 'project',
user = 'root',
passwd = '',
cursorclass = MySQLdb.cursors.DictCursor,
charset = 'utf8',
use_unicode = True)
def process_item(self, item, spider):
query = self.dbpool.runInteraction(self._conditional_insert, item)
query.addErrback(self.handle_error)
return item
def _conditional_insert(self,tx,item):
tx.execute(
"INSERT INTO raw (title,area,date,sclass,desc,pic )\
VALUES (%s, %s, %s, %s, %s, %s)",
(item['title'][0],
item['area'][0],
item['date'][0],
item['sclass'][0],
item['desc'][0],
item['pic'][0])
)
我的MySQL版本是5.6.17,mysql-python版本是1.2.5_
最佳答案
DESC
是 reserved keyword in MySQL 。如果您要命名列标识符 DESC
,您必须将其包含在刻度中:
tx.execute(
"INSERT INTO raw (title,area,date,sclass,`desc`,pic )\
VALUES (%s, %s, %s, %s, %s, %s)",
但是,更好的解决方案是不要使用保留关键字作为列标识符,因为它可能会在其他地方引起困惑和潜在的错误(加上完整的“描述”一词更清晰,并使代码更易于维护)。
tx.execute(
"INSERT INTO raw (title,area,date,sclass,description,pic )\
VALUES (%s, %s, %s, %s, %s, %s)",
关于Python mysql 错误#1064,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29145601/