SQLite 多线程串行写入

前端之家收集整理的这篇文章主要介绍了SQLite 多线程串行写入前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

确认在 "sqlite3.c" 中,宏 sqlITE_THREADSAFE = 1 或者 2
# define sqlITE_THREADSAFE 1 /* IMP: R-07272-22309 */

#include "Thread.h"

extern "C"
{
 #include "sqlite3.h"
};

#include <stdio.h>

#include "Utility.h"

//////////////////////////////////////////////////////////////////////////

int Print(void *pParam,int argc,char ** argv,char ** szColName)
{
 for (int i=0; i<argc; ++i) {
  printf("%s - %s,",szColName[i],argv[i]);
 }
 printf("\n");
 return 0;
}

//////////////////////////////////////////////////////////////////////////

class Demosqlite
{
 typedef ThreadT<Demosqlite> CThread;

public:
 Demosqlite(sqlite3 *psqlite3)
  : m_psqlite3(psqlite3)
 {
  m_lThreadCount = 0;

  m_threadRead.owner(this);
  m_threadWrite.owner(this);
 }

 VOID Start()
 {
  m_threadRead.Start(1);
  m_threadWrite.Start(4);
 }
 VOID Stop()
 {
  m_threadRead.Stop();
  m_threadWrite.Stop();
 }

 VOID Svc(CThread *pThread,HANDLE hExit)
 {
  char *errmsg= NULL;
  int result = 0;

  if (pThread == &m_threadRead) {
   CHAR szsql[128] = { 0 };
   while (TRUE) {
    if (WaitForSingleObject(hExit,1000) == WAIT_OBJECT_0) {
     break;
    }

    wsprintfA(szsql,"SELECT * FROM DemoTable WHERE Thread = 1");
    result = sqlite3_exec(m_psqlite3,szsql,Print,NULL,&errmsg);

    printf("\n\n\n");

    wsprintfA(szsql,"DELETE FROM DemoTable WHERE Thread = 1");
    result = sqlite3_exec(m_psqlite3,&errmsg);
   }
  }
  if (pThread == &m_threadWrite) {
   LONG lThread= InterlockedIncrement(&m_lThreadCount);
   LONG lCount = 0;

   CHAR szsql[128] = { 0 };
   while (TRUE) {
    if (WaitForSingleObject(hExit,1) == WAIT_OBJECT_0) {
     break;
    }

    wsprintfA(szsql,"INSERT INTO DemoTable VALUES(%d,%d)",lThread,lCount++);
    result = sqlite3_exec(m_psqlite3,&errmsg);
   }
  }
 }

private:
 sqlite3 *m_psqlite3;
 LONG m_lThreadCount;

 CThread m_threadRead;
 CThread m_threadWrite;
};

//////////////////////////////////////////////////////////////////////////

int main()
{
 sqlite3_config(sqlITE_CONFIG_SERIALIZED);

 char *errmsg = NULL;
 sqlite3 *psqlite= NULL;

 int result = OpenDatabase<0>(".\\Demosqlite.db",psqlite);
 if (result != sqlITE_OK) {
  return -1;
 }
 result = sqlite3_exec(psqlite,"CREATE TABLE IF NOT EXISTS DemoTable(Thread INTEGER,Count INTEGER)",&errmsg);
 result = sqlite3_exec(psqlite,"DELETE FROM DemoTable",&errmsg);

 Demosqlite demosqlite(psqlite);
 demosqlite.Start();
 Sleep(1000 * 5);

 demosqlite.Stop();
 sqlite3_close(psqlite);
 return 0;
}


猜你在找的Sqlite相关文章