python sql insert语句在数据库中插入带引号的值

2024-10-02 16:29:10 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图使用以下语句将数据插入python中的Mysql

cursor.execute('INSERT INTO batch_details (batch_id,plant_id,product_code) VALUES ("%s","%s","%s")', (id, plantcode, pcode))

此处id=“75”,plantcode=“2”,pcode=“FG”

但我在数据库中的值在mysql数据库中以单引号插入,即'75','2','FG'

我不知道为什么要用单引号插入这些值。sql查询的语法似乎是正确的


Tags: 数据id数据库executebatchmysql语句details
2条回答

%s表示您提供的值将被解释为字符串。对于要成为整数的,请尝试使用%d。如果希望SQL将值解释为数字而不是字符串,可能还需要去掉值列表中%d部分周围的引号字符

另外,当不同的程序或库打印字符串时,有些程序或库将使用单引号字符打印字符串,有些程序或库将使用双引号字符打印字符串。不管怎样,它仍然是数据库中的一个字符串,只是以不同的方式打印到屏幕上

您是否确保先将其转化为一份准备好的声明?请参阅文档示例here-

cursor = cnx.cursor(prepared=True)
stmt = "SELECT fullname FROM employees WHERE id = %s" # (1)
cursor.execute(stmt, (5,))

否则,如果您只想执行直接字符串操作,则应该执行以下操作

query = 'INSERT INTO batch_details (batch_id,plant_id,product_code) VALUES ("%s","%s","%s")'%(id, plantcode, pcode)
cursor.execute(query)

相关问题 更多 >