gpt4 book ai didi

python - 在 SQLite3 DELETE 语句中引用 python 变量

转载 作者:太空宇宙 更新时间:2023-11-04 08:15:05 24 4
gpt4 key购买 nike

我正在编写一个函数来从表中删除一条记录。我试图在删除语句中引用的变量是一个 Tkinter 输入字段。

我使用 .get() 方法获取变量,但我无法在不返回错误的情况下将其传递到 SQLite 语句中。

以下代码是框架的一部分,我只是在问题中添加了相关代码

from tkinter import *

import sqlite3

class EditOrdersForm(Frame):

def __init__(self):

Frame.__init__(self)
self.master.title("Edit Orders form:")
self.pack()

def displayDelOrderOptions(self):
self.deleteOrderOptionsLabel = Label(self, text="Enter the Order ID of the order you wish to delete: ").grid(row=numOrders+4, pady=2, sticky=W)
self.deleteOrderOptionsEntry = Entry(self, bd=3, width=10)
self.deleteOrderOptionsEntry.grid(row=numOrders+4, pady=5, column=1)
global orderToDelete
orderToDelete = self.deleteOrderOptionsEntry.get()
self.deleteButton = Button(self, text = "Delete this order", command = self.deleteOrder)
self.deleteButton.grid(row=numOrders+5, pady=5, column=1)
def deleteOrder(self):
conn = sqlite3.connect("testdb.db")
c = conn.cursor()

c.execute("DELETE FROM orders WHERE orders_id=:1)", (orderToDelete,))

conn.commit
c.close()

root = EditOrdersForm()
root.mainloop()

我遇到的问题是 WHERE 语句,我如何引用 orderToDelete。我试过将它转换为字符串并使用 (?) 作为参数,但这也不起作用。

最佳答案

parameterized 的正确语法查询是:

c.execute("DELETE FROM orders WHERE orders_id=?)", (orderToDelete,))

我相信你只需要调用提交而不是引用它

conn.commit()

关于python - 在 SQLite3 DELETE 语句中引用 python 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15972508/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com