猿问

在Python中的mysql.execute()语句中使用变量(对象)

我的 python 项目的以下代码似乎不起作用


import mysql.connector as sql  

    cxn=sql.connect(user='adithyan',password='vinod123',database='workout2')  

    cursor=cxn.cursor()  

    while True:

        try:

            l=[ ]  

            studentid =int(input("Please enter your student_id"))  

            a = 'select * from student_info where Student_ID = %studentid'  

            cursor.execute(a)    

            for i in cursor:  

                l.append(i)   

         except:    

            print("Student_id not found try again")

MySQL 连接没有问题,select 语句也没有问题(即,当我在 python 中独立运行时,查询运行是正确的),但 似乎我无法在 SQL 查询中使用 python 中的变量。另外,如果可能的话,请建议任何其他替代方案!

临摹微笑
浏览 182回答 2
2回答

幕布斯6054654

复杂性取决于给定输入的类型。如果你确定输入的类型,即是字符串还是数字,你可以直接采用Khan 的 Answer,字符串格式更好。几个例子:# Method 1(f-string) - if a numbera = f'select * from student_info where Student_ID = {studentid}'# if stringa = f"select * from student_info where Student_ID = '{studentid}'"否则,如果给我们的输入类型是动态的,即可以是字符串或数字,那么这里有一个适合于此的单行:a = 'select * from student_info where Student_ID = ' + (studentid if studentid.isnumeric() else "'"+studentid+"'")仅当没有给出其他条件时,即仅当串联不会产生不必要的复杂性时,上述情况才是可能的。您还可以使用 f-string:a = f'''select * from student_info where Student_ID = {(studentid if studentid.isnumeric() else "'"+studentid+"'")}'''

泛舟湖上清波郎朗

如果studentid是字符串,您的 sql 语句(或a变量)应该类似于:a =''' select * from student_info where Student_ID = '{studentid}'; '''.format(    studentid=studentid )如果它是整数(或数值),则不需要任何引号{studentid}:a =''' select * from student_info where Student_ID = {studentid}; '''.format(    studentid=studentid )
随时随地看视频慕课网APP

相关分类

Python
我要回答