【问题标题】:Python, Tkinter : insert request doesn't workPython,Tkinter:插入请求不起作用
【发布时间】:2022-01-15 01:06:15
【问题描述】:

我是 python 语言和 sql 请求的初学者。我不知道为什么,但是这段代码不起作用。它说我的要求不好。是因为我的变量类型吗?我尝试了几种解决方案,发现已经有几个与我的问题相关的 subjets。但我没有找到解决方案。

我的类ProviderWindow的代码:

    from tkinter import Tk, Label, Button, Entry, StringVar
    from GeStock_2 import provider


class ProviderWindow(Tk):
    def __init__(self):
        super().__init__()
        self.title("Provider")
        self.widgets_provider()

    def widgets_provider(self):
        # Input field for the new provider.
        name_provider = StringVar()
        provider_field = Entry(self, textvariable=name_provider)
        provider_field.grid(row=0, column=0)

        # Button to add a new provider.
        provider_add_button = Button(self, text="New provider")
        provider_add_button.grid(row=1, column=0, sticky="nesw")
        provider_add_button['command'] = lambda: call_function_insert_provider(name_provider)

def call_function_insert_provider(name_provider):
    new_provider = provider.Provider(name_provider)
    print(new_provider)
    print(str(new_provider))
    provider.Provider.insert_new_provider(new_provider)

我的班级提供者的代码:

from GeStock_2 import utils


class Provider(object):
    def __init__(self, name):
        self.name = name

    def insert_new_provider(self):
        conn = utils.connection()
        my_cursor = conn.cursor()
        print(self.name)
        print(str(self.name))
        my_cursor.execute("INSERT INTO `provider` (`id_prov`, `name_prov`) VALUES (NULL, ('" + str(self.name) + "')")
        cursor = my_cursor.fetchall()
        conn.commit()
        return cursor

“utils”代码:

导入 mysql.connector

def connection():
    # function that to connect to database.
    conn = mysql.connector.connect(user='root', password='', host='localhost', database='gestock_2')
    return conn

你能帮帮我吗?谢谢

【问题讨论】:

  • 尝试先构造INSERT SQL字符串并打印出来,然后你可能会看到SQL语句有什么问题。另外最好使用 placeholders 来避免 SQL 注入。

标签: python sql tkinter


【解决方案1】:

当你先构造 INSERT SQL 语句并打印出来时,如下所示:

sql = "INSERT INTO `provider` (`id_prov`, `name_prov`) VALUES (NULL, ('" + str(self.name) + "')"
print(sql)

假设self.name 的值为David,那么你将从print(sql) 得到如下:

INSERT INTO `provider` (`id_prov`, `name_prov`) VALUES (NULL, ('David')

NULL, 后面多了一个(

所以正确的是:

sql = "INSERT INTO `provider` (`id_prov`, `name_prov`) VALUES (NULL, '" + str(self.name) + "')"

不过最好使用占位符来避免SQL注入:

sql = "INSERT INTO `provider` (`id_prov`, `name_prov`) VALUES (NULL, %s)"
my_cursor.execute(sql, (self.name,))

更新:好像self.nameStringVar,所以应该改用self.name.get()

sql = "INSERT INTO `provider` (`id_prov`, `name_prov`) VALUES (NULL, %s)"
my_cursor.execute(sql, (self.name.get(),))

【讨论】:

  • 谢谢。我听从了你的回答并听取了你的建议。 PyCharm 在下面返回此错误。但是我认为我已经正确地将我的 viariable 放入了 str 类型。 ==> mysql.connector.errors.ProgrammingError:处理格式参数失败; Python 'stringvar' 无法转换为 MySQL 类型
  • 看来self.name 是一个tkinter StringVar,所以使用self.name.get() 而不是self.name
  • 现在可以了,谢谢
  • @Jean-baptisteBriois 如果可行,请考虑接受它作为答案。
  • 对此我很抱歉。我刚刚接受了。
猜你喜欢
  • 2013-06-26
  • 2016-03-27
  • 1970-01-01
  • 1970-01-01
  • 2016-08-22
  • 2011-08-27
  • 2020-12-20
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多