我创建了一个数据库,然后关闭并最终使用 os.remove 删除它,但是如果我尝试使用同一行创建相同的数据库,然后插入一个新表,编译器会说我无法在其中进行操作封闭的数据库。如果我添加 db.open() ,编译器会说它没有 open 属性。
我尝试在另一个定义上添加相同的连接线,但当很明显我删除了它然后创建了一个新数据库时,我仍然无法对“关闭”数据库进行操作。我也使用 pyqt5,这就是我写“QMainWindow”的原因
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow
from PyQt5 import uic
import sqlite3
import os
db = sqlite3.connect("prueba.db")
puntero = db.cursor()
#ayuda a este pobre noob que no sabe sqlite3 ni como funciona los argumentos dentro de un def()de python
class Ventana(QMainWindow):
def __init__(self):
QMainWindow.__init__(self)
uic.loadUi("base.ui",self)
self.btn_Tabla.clicked.connect(self.createTabla)
self.btn_Insertar.clicked.connect(self.createDatos)
self.btn_Borrar.clicked.connect(self.deleteBase)
self.btn_Crear.clicked.connect(self.createBase)
def createBase(self):
db = sqlite3.connect("prueba.db")
puntero = db.cursor()
self.txt_Base.setText("database created")
def createDatos(self):
x=1
def createTabla(self):
puntero.execute('''
CREATE TABLE Usuarios(id INTEGER PRIMARY KEY, Nombre TEXT,
Telefono TEXT, Correo TEXT unique, Contraseña TEXT)
''')
db.commit()
self.txt_Base.setText("tables inserted")
def deleteBase(self):
db.close()
os.remove("prueba.db")
self.txt_Base.setText("deleted database")
app = QApplication(sys.argv)
_ventana = Ventana()
_ventana.show()
app.exec_()
最佳答案
一个非常常见的错误是创建具有不同作用域的同名变量,认为一个变量会替换另一个变量,在您的情况下,您有 2 个变量 db:一个具有全局作用域,另一个具有函数 createBase 内的作用域。相反,重用相同的变量,而且您不应该假设一切正常,您必须在可能失败的情况下建立规则,例如,如果您调用 createTabla 两次以上,您不认为会产生问题吗?,检查是否.db 在尝试删除之前就已存在。
import sys
import os
import sqlite3
from PyQt5 import QtWidgets, uic
class Ventana(QtWidgets.QMainWindow):
def __init__(self):
super(Ventana, self).__init__()
uic.loadUi("base.ui",self)
self.btn_Tabla.clicked.connect(self.createTabla)
self.btn_Insertar.clicked.connect(self.createDatos)
self.btn_Borrar.clicked.connect(self.deleteBase)
self.btn_Crear.clicked.connect(self.createBase)
self.createBase()
def createBase(self):
self.db = sqlite3.connect("prueba.db")
self.puntero = self.db.cursor()
self.txt_Base.setText("database created")
def createDatos(self):
x=1
def createTabla(self):
try:
self.puntero.execute('''
CREATE TABLE IF NOT EXISTS Usuarios(id INTEGER PRIMARY KEY, Nombre TEXT,
Telefono TEXT, Correo TEXT unique, Contraseña TEXT)
''')
self.db.commit()
self.txt_Base.setText("tables inserted")
except sqlite3.ProgrammingError as e:
print("Error: ", e)
def deleteBase(self):
self.db.close()
if os.path.exists("prueba.db"):
os.remove("prueba.db")
self.txt_Base.setText("deleted database")
if __name__ == '__main__':
app = QtWidgets.QApplication(sys.argv)
_ventana = Ventana()
_ventana.show()
sys.exit(app.exec_())
关于python - 如何在 SQLITE3 上关闭和删除数据库后再次打开数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55346197/