MS Access 数据库被 Python 锁定
MS Access database locked by Python
我正在使用 Python 将数据框写入 MS Access 数据库。它有效,但我似乎无法关闭连接(即数据库被 Python 锁定)。
这是我的代码:
# imports
import urllib
import pyodbc
import pandas as pd
from sqlalchemy import create_engine
# connection
connection_string = (
r'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};'
r'DBQ=M:\Larry\Access\test2.accdb;'
r'ExtendedAnsiSQL=1;'
)
connection_uri = f"access+pyodbc:///?odbc_connect={urllib.parse.quote_plus(connection_string)}"
engine = create_engine(connection_uri)
# create dataframe
d = {'name':['daryl','other daryl'],'team':['a','b']}
df = pd.DataFrame(d)
# write to database
df.to_sql('test',engine,if_exists='replace',index=False)
我尝试在创建引擎行之后添加:
conn = engine.connect()
在将数据帧写入数据库之后:
conn.close()
我没有收到这些添加项的错误,但数据库仍处于锁定状态。如何关闭连接以解除锁定?
由于维护的是数据库与engine对象的连接实例,运行后,考虑Engine.dispose()
释放资源:
...
# write to database
df.to_sql('test', engine, if_exists='replace', index=False)
engine.dispose()
我正在使用 Python 将数据框写入 MS Access 数据库。它有效,但我似乎无法关闭连接(即数据库被 Python 锁定)。
这是我的代码:
# imports
import urllib
import pyodbc
import pandas as pd
from sqlalchemy import create_engine
# connection
connection_string = (
r'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};'
r'DBQ=M:\Larry\Access\test2.accdb;'
r'ExtendedAnsiSQL=1;'
)
connection_uri = f"access+pyodbc:///?odbc_connect={urllib.parse.quote_plus(connection_string)}"
engine = create_engine(connection_uri)
# create dataframe
d = {'name':['daryl','other daryl'],'team':['a','b']}
df = pd.DataFrame(d)
# write to database
df.to_sql('test',engine,if_exists='replace',index=False)
我尝试在创建引擎行之后添加:
conn = engine.connect()
在将数据帧写入数据库之后:
conn.close()
我没有收到这些添加项的错误,但数据库仍处于锁定状态。如何关闭连接以解除锁定?
由于维护的是数据库与engine对象的连接实例,运行后,考虑Engine.dispose()
释放资源:
...
# write to database
df.to_sql('test', engine, if_exists='replace', index=False)
engine.dispose()