Всякий раз, когда я пытался ввести новые данные в базу данных с помощью SQL-запроса в python, он отображает ошибку типа «У вас есть ошибка в вашем синтаксисе SQL; обратитесь к руководству, соответствующему вашей MariaDB
версии сервера, для правильного синтаксиса для использовать рядом с '(' сотрудник ').
проблема в (elif value == 2)
блоке
import pymysql
import time
def student_database():
storage = input("Enter your database name :")
table = input("Enter your table name")
print("Press 1 for Displaying Data -->")
print("Press 2 for entering new Data..")
print("press 3 for adding new column to table..")
print("press 4 for modifying data in table")
value = int(input())
db = pymysql.connect(host='localhost', database=storage, user='', passwd='')
cursor = db.cursor()
print("Connected to " + storage)
if value == 1:
print("Printing Data :\n")
cursor.execute("SELECT * FROM (%s)" %(table))
for row in cursor:
print(row)
elif value == 2:
print("Enter New Values to be entered")
first = input("Enter First Name: ")
last = input("Enter Last Name: ")
age = input("Enter Age: ")
sex = input("Enter Sex: ")
salary = input("Enter salary amount: ")
no = input("Enter number")
# query for adding data into table
cursor.execute("INSERT INTO (%s) VALUES (%s, %s, %s, %s, %s, %s)", (table, first, last, age, sex, salary, no))
db.commit()
print("Data entered Succesfully")
elif value == 3:
print("Enter column name to be added")
column_name = input("enter new column name")
#query for adding new column in existing table
cursor.execute("Alter table employee add %s VARCHAR(10)" %column_name)
db.commit()
print("column Added successfully")
elif value == 4:
field_name = input("enter field name to be updated :")
new_value = input("Please enter your new value")
reference_name = input("enter reference column name :")
reference_value = input("enter reference value :")
cursor.execute("update employee set %s = %s WHERE %s = %s" % (field_name, new_value, reference_name, reference_value))
db.commit()
print("data modified succesfully ")
while(True):
student_database()
time.sleep(3)
если value == 2
, то нужно взять некоторые данные и ввести те же данные в таблицу сотрудников.