- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我从 http://ch-werner.de/sqliteodbc/ 下载并安装了 SQLite ODBC 驱动程序.在一个问题上效果很好。如果另一个应用程序打开了数据库,我似乎无法获得排他锁。
我正在使用一个名为 Altium 的 CAD 应用程序。我正在尝试在 SQLITE 中构建一个原型(prototype)零件数据库来存放数据。我安装了上面提到的 ODBC 驱动程序,我可以很好地获取数据。问题是,如果我尝试在 SQLITEStudio 或 DB Browser for SQLITE 之类的应用程序中打开同一个数据库,我永远无法获得独占锁来写入新记录。 Altium 从不关闭它的连接,我不知道这是否是问题所在。
当我阅读 https://www.sqlite.org/lockingv3.html这似乎表明多个进程需要进行通信才能获得排他锁(写入所必需的)。这让我相信我的问题是第一个应用程序永远不会释放它的共享锁,因此第二个应用程序永远无法获得独占锁。我是否正确解释了这一点?
最佳答案
我在使用 SQLite 作为 Altium 数据库时遇到了同样的困难。当 Altium 打开并创建了与数据库的连接时,无法更新数据库文件。到目前为止,我发现了两种解决方法:
启用 Write Ahead Logging风格数据库杂志
默认数据库日志样式 DELETE 会临时创建数据库副本,写入数据库文件,并在验证写入时删除临时副本。
预写日志记录 WAL 将所有更改放在一个临时文件中,同时保留数据库的原始副本。访问数据库的进程解析数据库文件和 WAL 临时文件,并返回反射(reflect)所有更改的信息。我可以确认在 Altium 中进行数据库刷新时可以看到 Altium 之外的写入。
当检查点操作发生时,存储在 WAL 文件中的写入将写入原始数据库。当进程调用 PRAGMA wal_checkpoint;
时或者在 WAL Auto Checkpoint 设置指定的一些操作之后。
您可以在 DB Browser 中启用 WAL 日志模式的编辑编译指示选项卡:
DB Browser Database Settings
不过,问题仍然没有解决。 Altium 打开时,检查点数据库不起作用。数据库文件仍处于锁定状态,无法更改。
需要注意的是,我们希望在 Git 中备份和维护数据库文件的历史记录(是的,不推荐使用 Git)。在 Git 中不会跟踪对日志文件的写入,在检查点之前不会看到数据库文件中的更改。这意味着我们不能在 Altium 打开时从 Git 推送或拉取。我们可以跟踪数据库和日志文件,但另一个结果是没有数据更改的简单检查点将被 Git 视为更改。
使用替代的 ODBC 驱动程序
我测试了另一种专有的ODBC driver从德瓦特。当我将 Altium 配置为使用 devart 驱动程序连接到 SQLite 数据库时,无论日志设置如何,DB Browser 在 Altium 打开时写入文件都没有问题。 Altium 还可以通过刷新操作查看这些更改。
结论
克里斯蒂安·沃纳的 ODBC driver (从 0.9996 版开始)以 devart 驱动程序不锁定的方式锁定文件,即使 Atlium 通过驱动程序保持与数据库的连接。在某些情况下,WAL 日志模式可能是一种解决方法。
关于SQLITE ODBC 驱动程序和数据库锁定,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45269190/
我刚刚用 java-swing 为我写了一个桌面时钟,我希望每次登录时该时钟都运行。 为此,我将我的 jar 文件添加到 start 文件夹,我让时钟开始运行。 但我的问题是 - 任务栏中显示的图标允
我正在尝试编写一个程序来检查用户是否上传了新视频。我想让它成为一项后端工作,不断检查用户最近的视频,然后使用我的应用程序向我的用户发送推送。有关于这个问题的任何文档或示例代码吗?我完全不知道从哪里开始
我正在为我的 Raspberry Pi 编写一个程序,该程序由两个主要部分组成: 使用 Spotify-API“Libspotify”搜索音乐并播放音乐的 C 程序。 一个在 apache2 We
我做了一个C++生成命令行并将命令转发给它的程序。目前,我正在将 cmd 控制台的输出发送到一个文件,并在我的 C++ 程序中读取它。但我想让它与管道一起工作。 是否可以从 Windows cmd 行
是否可以使用 C 程序和 malloc 找出处理器的页面大小?而不是使用 sysconf() 调用? 最佳答案 如果你可以#include一些linux内核头文件,你可以在中找到宏PAGE_SIZE
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我想实现一个算法: 从 Ruby on Rails 应用程序获取数据库对象作为输入, 对输入执行计算, 根据计算查询 Rails 数据库, 并根据查询生成一组有序结果。 我将用 C(也许是 Objec
我今天的任务是创建一个 Python 脚本(例如 A.py),它可以执行以下操作: 启动 C 程序(例如 CProg)并传递一些参数 启动另一个 Python 脚本(例如 B.py)并传递其他参数 加
我有一个在后台运行的 .NET 程序,需要创建一个可以与该程序通信的 Windows Shell 扩展。起初我以为我会在 .NET 中创建我的 Shell Extension,并使用 IpcServe
Python 程序做前端工作,C 程序做后端工作。它们中的每一个都是一个单独的过程。 Python 进程充当主进程,向 C 进程发送信号和事件。 C 进程生成统计信息、计数器和信息,这些信息被发送回
如何与 shell 脚本共享 C 头文件? shell 脚本通过命名管道与 C 程序通信。让我们假设 C 头文件中定义的枚举 SAMPLE_ONE 由 C 程序写入管道。 shell 脚本从管道中读出
我有一些客户/候选人提示我的程序不能在他们的 Windows 7 64 位版本上运行(已通过屏幕截图确认)。错误很奇怪,例如: in the trial version i am getting a
这个问题在这里已经有了答案: Why SDL defines main macro? (2 个答案) 关闭 7 年前。 我在 Windows 操作系统下使用 QT Creator 的简单程序中使用
我的导师给了我们一个基本的 C shell 来扩展,我目前正在努力让 shell 在用户在命令行中输入“cd [directory]”时更改目录。我已经得到它来停止段错误,但它不会更改目录。谁能告诉我
我以前有过这个工作,但我使用的是指针。 getenv() 不断崩溃,所以我使用 sprintf() 复制了结果。现在我想用 : 删除并只打印第一次出现的地方。请帮忙! #include #inclu
你好,我第一次使用 C primer plus book 学习 C,然后在第 16 章关于 C11 标准的 _Generic 我在 Eclipse c/c++ 中编写了一个程序并构建它产生了 8 个错
我正在尝试从另一个 C 程序执行 python 程序,其中 py 脚本的返回值为 int array[3] 我可以从 python 退出代码中获取这个数组吗?? 编辑:如果问题不清楚,我可以将 pyt
// The countChicken() method should count the number of occurrences of the word chicken (or some oth
我已经通过 ZMQ 使用同一类成功地从 C# 和 C++ 程序传输数据,其中 C++ 类是数据定义,编译器幸运地将字节数组屏蔽到类。 我如何在 C# 和 Node.js 程序之间做同样的事情?我认为他
任何人都可以为我指明有关 makefile 如何工作以及如何使用 eclipse 从头开始基本程序的好教程的方向吗?我正在为 fedora 和 C++ 使用 eclipse 3.4.1 版。提前致
我是一名优秀的程序员,十分优秀!