Ошибка при вставке значений переключателей в базу данных oracle из python - PullRequest
0 голосов
/ 20 апреля 2020

Ссылка на мой предыдущий вопрос.

Я работаю над проектом, который в основном будет задавать пользователям 3 вопроса, и ответы будут доступны в виде переключателей с 2 ​​вариантами. После выбора кнопки «Отправить» после выбора параметров мне нужно вставить значения в базу данных oracle. Теперь, когда я пытаюсь добавить некоторые переменные, которые я уже установил, я получаю сообщение об ошибке как cx_Oracle.DatabaseError: ORA-01036: illegal variable name/number

. Я создал таблицу в базе данных oracle, которая называется "Survey", в которой есть поля ниже 1) STAFFID 2 ) МАШИНА 3) CURRENT_TIME 4) ДЕНЬ 5) НАСТРОЙКА 6) РАБОТА

Мне нужна помощь по

1) Как вставить переменные в качестве значений в базу данных? ( staffid, machine, date_str - это значения, которые я пытаюсь вставить в поля базы данных STAFFID, MACHINE, CURRENT_TIME )

2) Как вставить радио значения кнопок day_selected, mood_selected и work_selected в полях базы данных DAY, MOOD, WORK

ниже мой код.

from tkinter import *
import tkinter.messagebox
import getpass
import socket
from datetime import datetime

root=Tk()
root.title("Survey")
root.geometry("225x225")
root.config(bg="antique white")
root.resizable(width="false", height="false")


day_selected = IntVar()
mood_selected = IntVar()
work_selected = IntVar()

# creating values for entry

staffid = getpass.getuser()
machine = socket.gethostname()
now = datetime.now()
date_str = now.strftime("%Y/%m/%d %H:%M:%S")
day_sel = day_selected.get()

def done():
    print(staffid)
    print(machine)
    print(date_str)
    print(day_sel)
    print("Good" if day_selected.get()==1 else "BAD")
    print("Good" if mood_selected.get()==3 else "BAD")
    print("Good" if work_selected.get()==5 else "BAD")
    dsn_tns = cx_Oracle.makedsn('server', 'port', service_name='XXXX.XX.XXXX')
    conn = cx_Oracle.connect(user=r'XXXX', password='XXXX', dsn=dsn_tns)
    cur = conn.cursor()
    cur.execute("INSERT INTO SURVEY (STAFF_ID, HOST_NAME, CURRENT_TIME, DAY, MOOD, WORK) VALUES (%s, %s, %s, %s, %s, %s)",
                (staffid, machine))
    conn.commit()
    cur.close()
    conn.close()
    tkinter.messagebox.showinfo("Thank you", "Thank you for completing the survey !!!")

lab1 = Label(root, text="  How Was ?", font=("calibri", 20, "bold"), bg="antique white", fg="brown").pack()
lab2 = Label(root, text="Day", font=("calibri", 14, "bold"),bg="antique white")
lab2.place(x=8, y=50)
r1=Radiobutton(root,text="Good", font=("calibri",12), variable=day_selected, value=1,bg="antique white").place(x=110,y=52)
r2=Radiobutton(root,text="Bad",font=("calibri",12), variable=day_selected, value=2,bg="antique white").place(x=170,y=52)
lab3 = Label(root, text="Mood", font=("calibri", 14, "bold"),bg="antique white")
lab3.place(x=8, y=100)
r3=Radiobutton(root,text="Good", font=("calibri",12), variable=mood_selected, value=3,bg="antique white").place(x=110,y=102)
r4=Radiobutton(root,text="Bad",font=("calibri",12), variable=mood_selected, value=4,bg="antique white").place(x=170,y=102)
lab4 = Label(root, text="Work", font=("calibri", 14, "bold"),bg="antique white")
lab4.place(x=8, y=150)
r5=Radiobutton(root,text="Good", font=("calibri",12), variable=work_selected, value=5,bg="antique white").place(x=110,y=152)
r6=Radiobutton(root,text="Bad",font=("calibri",12), variable=work_selected, value=6,bg="antique white").place(x=170,y=152)

sub_bt=Button(root, text="Submit",font=("calibri",12, "bold"), command=done, bg="brown", fg="white").pack(side=BOTTOM)

root.mainloop()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...