D B Browser.Sqlite.OperationalError:数据库被锁定

问题描述

我正在尝试将表单提交到 DB browser sqlite。我已经创建了一个表。我能够将数据存储到 sqlite 中。但是,一旦我在提交按钮(submitclaim.html)中添加一个执行确认弹出框的函数,我就会显示这个错误

sqlite3.OperationalError: database is locked

当我尝试向表格提交表单时,它发生在行上:

    c.execute("INSERT INTO SubmitClaim VALUES (?,?,?)",(depart,type,uploadre,amt,description)

这是我的 app.py

@app.route('/addrec',methods=['POST','GET'])
def addrec():
    if request.method == 'POST':

        depart = request.form['depart']
        type = request.form['type']
        uploadre = request.form['uploadre']

        amt = request.form['amt']
        description = request.form['description']

    conn = sql.connect(db_path)
    c = conn.cursor()

    c.execute(
        "INSERT INTO SubmitClaim VALUES (?,description))

    conn.commit()

    c.execute("SELECT * FROM  SubmitClaim")
    print(c.fetchall())
    conn.close()

    return render_template('base.html',user=session["user"],version=msal.__version__)
     

这是我的 SubmitClaim.html

<div class="arrange3">
    <button onclick="myFunction()" type="submit" class="submit-button" name="save",value="save">Submit</button>
    <script>
    function myFunction() {
    confirm("Press a button!");
    }

解决方法

您只需要在 DB Browser SQLITE 中关闭数据库并运行代码

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...