Qt-共享同一数据库的应用程序

时间:2018-06-22 19:36:53

标签: c++ qt qt-creator qsqldatabase

我有一个使用以下应用程序:

QString databasePath = QStandardPaths::writableLocation(QStandardPaths::ConfigLocation);
    databasePath += "/MyApp.db";
    qApp->setProperty("MYAPP_DATABASE_PATH", databasePath);

为数据库创建路径

是否有办法使另一个应用程序使用相同的路径访问相同的数据库?

1 个答案:

答案 0 :(得分:0)

通过SQlite常见问题解答:

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