为了账号安全,请及时绑定邮箱和手机立即绑定

使用python在mysql中插入字符串:未知列

使用python在mysql中插入字符串:未知列

白衣染霜花 2021-08-05 15:09:14
首先,我是初学者,我提前感谢您的帮助:)当我插入一个字符串时,它给了我一个错误双引号或单引号。这只发生在我调用我创建的函数 insert() 时。但是当我只是用一个数字代替那些没有引号的字符串时,它就可以工作了。import mysql.connectorconn = mysql.connector.connect(user="root",password='password',       host='localhost',database='library',port='3306')cur = conn.cursor()def create_table():    cur.execute("CREATE TABLE IF NOT EXISTS store                (id INT PRIMARY KEY, item VARCHAR(25), quantity INT, price REAL);")    conn.commit()    conn.close()def insert(id, item, quantity, price):    cur.execute("INSERT INTO store (id, quantity, price, item)                 VALUES (%s, %s, %s, %s)" % (id, item, quantity, price))    conn.commit()    conn.close()insert(50, 'test', 20, 10)然后它给出了一个错误:Traceback (most recent call last):      File "C:\Program Files\Python36\lib\site- packages\mysql\connector\connection_cext.py", line 392, in cmd_query        raw_as_string=raw_as_string)    _mysql_connector.MySQLInterfaceError: Unknown column 'test' in 'field list'    During handling of the above exception, another exception occurred:    Traceback (most recent call last):      File "C:\Users\Acer\Desktop\Remastered.py", line 128, in <module>        insert(50, 'test', 20, 10)      File "C:\Users\Acer\Desktop\Remastered.py", line 109, in insert        cur.execute("INSERT INTO store (id, quantity, price, item) VALUES (%s, %s, %s, %s)" % (id, item, quantity, price))      File "C:\Program Files\Python36\lib\site-packages\mysql\connector\cursor_cext.py", line 266, in execute        raw_as_string=self._raw_as_string)      File "C:\Program Files\Python36\lib\site-packages\mysql\connector\connection_cext.py", line 395, in cmd_query        sqlstate=exc.sqlstate)    mysql.connector.errors.ProgrammingError: 1054 (42S22): Unknown column 'test' in 'field list'    [Finished in 0.8s with exit code 1]
查看完整描述

2 回答

?
隔江千里

TA贡献1906条经验 获得超10个赞

您没有正确使用占位符功能。正确的行是:

cur.execute("INSERT INTO store (id, quantity, price, item) 
            VALUES (%s, %s, %s, %s)", (id, item, quantity, price))

注意,不是 %会造成严重的SQL 注入错误

您的查询已扩展为以下内容:

INSERT INTO store (...) VALUES (1, test, 1, 1.0);

test部分根本没有被引用并被视为可能的列名。


查看完整回答
反对 回复 2021-08-05
  • 2 回答
  • 0 关注
  • 199 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信