`
逆风的香1314
  • 浏览: 1440458 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Sqlite内存数据库在多线程下的使用问题

阅读更多
WINDOWS平台,多线程服务器,我想创建一个全局内存数据库,然后在其他线程里面使用这个库,包括读写,弄的时候发现有几个问题:

1  方法一:程序启动时创建一个全局Sqlite连接,各个线程都可以操作这个实例。但经测试发现,这么做,如果不做同步,读写都会冲突。也就是说,无论读写,只能有一个线程操作该实例,这样未免也太痛苦了,读也需要同步,效率降低太多。

2  方法二:如果把数据库创建到文件,那么可以在创建每个服务线程里面打开这个数据库,然后操作,这样就不需要处理同步了。(读不需要同步,写Sqlite自己做了同步LOCK)
   不过如果把数据库建立到内存,好像就不能这样了:
   全局数据库用sqlite_open(":memory:",&db)创建,但在子线程里面如果也用sqlite_open(":memory:",&db)得到的是一个空数据库。事实上,即使在同一个线程里面这样做:
sqlite3* db1=NULL;
sqlite3* db2=NULL;
sqlite3_open(":memory:",&db1);
//在db1中创建表,填数据等等
sqlite3_open(":memory:",&db2);//这时候得到的db2是一个空的数据库

   在这种情况下如何才能得到先前已经创建的内存数据库?


第 1 楼    xiao_fang(frank)
2006-4-7 17:10:52
得分:100   返回顶部

可能受到Sqlite自身限制,你可下载源码看一下sqlite3_open对于内存数据库是如何处理的
第 2 楼    lsgt()
2006-4-7 17:38:16
得分:0   返回顶部

就是没看懂啊。不知道有没有达人知道如何处理这样的问题? 
分享到:
评论

相关推荐

    sqlite3.24数据库支持多线程

    #SQLITE_配置_多线程 各个线程使用不同的连接和准备的SQL语句。#SQLITE_配置_串行化 启用所有互斥锁,多个线程都可以使用相同的连接和准备的SQL语句。当然还有一些配置我没有封装完,基本是些内存方面的。另外编译了...

    QT中sqlite多线程操作4个注意问题

    多线程下的各个线程或定时器数据库驱动加载需独立进行 在多线程环境中,不同线程间共享资源会导致各种难以预料的问题。对于SQLite数据库而言,如果多个线程试图同时访问同一个数据库实例,则很容易出现死锁或其他...

    易语言-sqlite3.24数据库支持多线程

    #SQLITE_配置_多线程 各个线程使用不同的连接和准备的SQL语句 #SQLITE_配置_串行化 启用所有互斥锁,多个线程都可以使用相同的连接和准备的SQL语句 当然还有一些配置我没有封装完,基本是些内存方面的 另外编译了...

    C#解决SQlite并发异常问题的方法(使用读写锁)

    使用C#访问sqlite时,常会遇到多线程并发导致SQLITE数据库损坏的问题。 SQLite是文件级别的数据库,其锁也是文件级别的:多个线程可以同时读,但是同时只能有一个线程写。Android提供了SqliteOpenHelper类,加入Java...

    android sqlite多线程和异步加载数据库数据示例

    在这个示例中,我们将探讨如何在Android中进行多线程数据库操作以及如何利用CursorAdapter实现异步加载数据库数据。 首先,我们来看多线程访问SQLite数据库。在Android中,主线程负责UI的更新和交互,而长时间运行...

    C#工具包 dataGridView sqlite 多线程

    在dataGridView的批量删除、文件操作或数据库操作中,多线程可以提升用户体验,但需注意线程同步和资源竞争问题,防止数据不一致。 这个"C#工具包"项目整合了丰富的功能,不仅展示了C#的基本使用,还涵盖了网络通信...

    多进程写sqlite互斥解决方案代码

    以下是一个简单的Python示例,展示了如何在多进程或多线程环境下使用互斥锁写入SQLite数据库: ```python import sqlite3 from multiprocessing import Process, Lock from threading import Thread def write_db...

    数据库sqlite3 vs2010

    - 考虑线程安全,如果多线程访问数据库,可能需要使用线程局部存储或互斥锁来同步访问。 综上所述,SQLite3与C++结合在VS2010中可以构建高效、可靠的本地数据库应用程序。理解SQLite3的基本操作、C++接口的使用...

    sqlite3.30.1 数据库模块+支持库(彻底解决多线程死锁问题)-易语言

    SQLite3.30.1是SQLite数据库引擎的一个特定版本,专为易语言用户设计,旨在提供一个高效且可靠的多线程数据库解决方案,特别是在处理可能引发死锁问题的并发操作时。SQLite是一个开源、轻量级的嵌入式数据库,常用于...

    sqlite数据库 大数据量处理demo

    9. **并发控制**:SQLite支持多线程操作,但并发访问时需注意锁的使用,以防止数据冲突和死锁。 10. **硬件配置**:提升存储设备的速度,如使用SSD,可以显著提高SQLite处理大数据时的读写性能。 在"BarCodeTest...

    sqlite3-stress:多线程写入Sqlite3数据库

    了解了“sqlite3-stress”工具及其工作原理后,开发者可以通过调整数据库配置、优化查询语句、使用适当的事务隔离级别等方式,提升SQLite3在多线程环境下的性能。此外,也可以通过监控工具分析测试结果,找出性能...

    Sqlite数据库支持库

    9. **内存数据库模式**:除了传统的磁盘数据库,SQLite还支持内存数据库,数据只存在于内存中,适用于临时存储或测试场景。 10. **嵌入式应用**:SQLite特别适合嵌入式系统,因为它的体积小、资源占用低,且无需...

    火山安卓Android内置数据库+Sqlite.rar

    【标题】"火山安卓Android内置数据库+Sqlite.rar" 提供的是关于在安卓...通过学习这些内容,开发者可以掌握在火山安卓环境下使用SQLite进行数据管理的核心技术,从而有效地在Android应用中构建功能丰富的数据库系统。

    用sqlite数据库做的英语字典

    此外,对于Android等移动平台,可能需要考虑线程安全问题,避免多个并发请求导致的数据冲突。 在实际应用中,可能还会涉及到其他功能,比如单词的搜索历史记录、学习进度跟踪、用户反馈等。这些可以通过添加额外的...

    SQlite数据库源码

    支持多线程操作,有多种锁定机制保证在多用户环境下的并发访问。同时,它提供了安全的备份和恢复功能。 6. **API接口**: SQLite提供了C语言的API接口,供开发者在各种平台上集成和使用。此外,还有许多语言的...

    sqlite数据库源码

    SQLite是一款开源、免费的嵌入式关系型数据库系统,它以其轻量级、无服务器、零配置、事务支持等特性,在各种应用场景下被广泛应用。SQLite的源码是完全公开的,开发者可以深入研究其内部机制,理解数据库引擎的工作...

    内存文件数据库

    4. 并发控制:在多线程环境下,确保数据的一致性和完整性,如使用锁、事务等机制。 5. 性能优化:通过索引、数据压缩、预读取等手段提高查询效率。 6. 数据安全性:加密存储,防止数据泄露;备份策略,防止数据丢失...

    sqlite 嵌入式数据库介绍

    SQLite 的设计使得它能够在单个库文件中包含数据库引擎和接口,运行时不需要依赖额外的库,这极大地简化了部署和使用。 SQLite 的优势在于其小巧的内存占用和快速的性能,相对于 MySQL 和 PostgreSQL 等其他数据库...

    Sqlite3数据库源码_ios源码

    4. **多线程支持**:SQLite3允许在一个进程中多个线程同时访问数据库,但对并发控制有特定限制,需要开发者根据应用需求谨慎设计。 5. **空间效率**:SQLite3采用动态类型系统,自动根据数据类型存储,减少了内存和...

Global site tag (gtag.js) - Google Analytics