当我需要从actions
表中删除记录时,出现了数据库锁定错误。
有两个程序在一个sqlite3数据库上进行读写操作。
其中一个是C程序,将硬件操作的结果写入sqlite3表中,另一个是Python脚本,从sqlite读取记录并处理它们,在完成任务后删除行。
但是Python脚本在删除行时显示数据库已锁定
错误。
数据库名称:db.db
数据库表:
TABLE 'actions' (
'rid' INTEGER PRIMARY KEY AUTOINCREMENT,
'owner' INTEGER,
'action' TEXT,
'node' TEXT,
'value' TEXT
Python脚本:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import sqlite3
import time
import os.path
import requests
#import urllib.parse
#defines
BASE_DIR = os.path.dirname(os.path.abspath(__file__))
db_path = os.path.join(BASE_DIR+"/dbs/", "db.db")
wd_file_path = os.path.join(BASE_DIR, "wd")
pid = os.getpid()
conn = sqlite3.connect(db_path, isolation_level=None ,timeout=30000)
print ("Opened database successfully");
while True:
res = conn.execute("select * from 'actions' where 'owner'='1';")
#conn.commit()
data=res.fetchone()
print(data)
if (data is None) :
print('nothing @ '+str(time.time()))
with open(wd_file_path, 'w') as file_:
file_.write("{'pid'='"+str(pid)+"','time'='"+str(time.time())+"'}")
time.sleep(0.5)
else:
#print(data)
r = requests.post("http://127.0.0.1/json.php", data={'act': data[2], 'val': data[4]})
#if (r.text == '1'):
conn.execute("delete from 'actions' where 'rid'="+str(data[0])+";")
conn.commit()
#else:
# print(r.text)
正如您所看到的,我在连接中放置了 isolation_level=None
和 timeout=30000
但是我经常遇到数据库锁定错误
while True:
中打开和关闭连接。 - roozgar