我有一个使用以下应用程序:
QString databasePath = QStandardPaths::writableLocation(QStandardPaths::ConfigLocation);
databasePath += "/MyApp.db";
qApp->setProperty("MYAPP_DATABASE_PATH", databasePath);
为数据库创建路径
是否有办法使另一个应用程序使用相同的路径访问相同的数据库?
答案 0 :(得分:0)
通过SQlite常见问题解答:
SQLite使用读取器/写入器锁来控制对数据库的访问。 (在Win95 / 98 / ME中,它不支持读取器/写入器锁定,而是使用概率模拟。)但是请小心:如果数据库文件保存在NFS文件系统上,则该锁定机制可能无法正常工作。这是因为fcntl()文件锁定在许多NFS实现中都被破坏了。如果多个进程可能试图同时访问文件,则应避免将SQLite数据库文件放在NFS上。在Windows上,Microsoft的文档说,如果您没有运行Share.exe守护程序,则锁定可能在FAT文件系统下不起作用。拥有丰富Windows经验的人告诉我,网络文件的文件锁定非常容易出错,并且不可靠。如果他们说的是真的,那么在两个或更多Windows计算机之间共享SQLite数据库可能会导致意外问题。