[英]Qt - Applications sharing the same database
我有一个使用以下应用程序:
QString databasePath = QStandardPaths::writableLocation(QStandardPaths::ConfigLocation);
databasePath += "/MyApp.db";
qApp->setProperty("MYAPP_DATABASE_PATH", databasePath);
为数据库创建路径
有没有办法让另一个应用程序使用相同的路径访问相同的数据库?
从SQlite常见问题解答:
SQLite使用读取器/写入器锁来控制对数据库的访问。 (在Win95 / 98 / ME中,它不支持读取器/写入器锁定,而是使用概率模拟。)但是请小心:如果数据库文件保存在NFS文件系统上,则该锁定机制可能无法正常工作。 这是因为fcntl()文件锁定在许多NFS实现中都被破坏了。 如果多个进程可能试图同时访问文件,则应避免将SQLite数据库文件放在NFS上。 在Windows上,Microsoft的文档说,如果您没有运行Share.exe守护程序,则锁定可能在FAT文件系统下不起作用。 拥有丰富Windows经验的人告诉我,网络文件的文件锁定非常容易出错,并且不可靠。 如果他们说的是真的,那么在两台或更多台Windows计算机之间共享SQLite数据库可能会导致意外问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.