青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Codejie's C++ Space

Using C++

LingosHook:wxSQLite3不錯


??? Lingoes界面上的‘語言’字串可以選擇不同的語言,這樣導致其窗口的‘標題’不同,因此對于不同‘語言’界面的Lngoes還需要使用不同的字串傳給FindWndow。這個開始還真沒注意。
??? 另一個問題,當前沒有找到好的HTML Parser,于是打算采用直接分解‘text’的方式獲得結果。這樣做會使結果的處理非常的‘受限’,比如如果選擇了多個詞典,text方式處理起來就非常麻煩了。因此當前就先采用‘text’方式,處理一個默認字典先。
??? 今天發現wxSQLite3好用,和其封裝MySQL++類似,又能迎合wxWidgets的類型,用起來比較順手。今天的主要動作也是集中在LingosHook本地數據庫的設計和訪問接口的實現上,應該說寫好了,就差合并使用了,這個明天再說吧。

??? wxSQLite3相關代碼如下,記錄一下,下次再用wxSQLite3就有參考了。第一次用,有錯誤再說吧,嘿嘿~


#include?
<vector>

#include?
"wx/wx.h"

#include?
"wx/wxsqlite3.h"

class?CDBAccess
{
public:
????
static?const?wxString?TABLENAME_WORD;
????
static?const?wxString?TABLENAME_DICTIONARY;
????
static?const?wxString?TABLENAME_RESULT;

????
static?const?wxString?WORDCLASS_NOUN;
public:
????
enum?WordClass?{?WC_UNKNOWN?=?-1,?WC_NOUN?=?0?};
????typedef?std::pair
<int,?wxString>?TResultPair;//wordclass?+?result
????typedef?std::vector<TResultPair>?TResultVector;
????typedef?std::pair
<wxString,?TResultVector>?TRecordPair;//dictionary+result?vector
????typedef?std::vector<TRecordPair>?TRecordVector;
????typedef?
struct?_RecordData_t
????
{
????????wxString?m_strWord;
????????wxString?m_strSymbol;
????????TRecordVector?m_vctResult;
????????wxString?m_strHTML;
????}
?TRecordData;
public:
????CDBAccess();
????
virtual?~CDBAccess();

????
int?Init(const?wxString&?dbfile);
????
????
int?Insert(const?TRecordData&?record);
????
int?Remove(const?wxString&?word);
????
int?Search(TRecordData&?record);
protected:
????
int?InitTables();
????
void?Close();

????
int?InsertWordTable(const?TRecordData&?record,?wxLongLong&?id);
????
int?InsertDictTable(const?wxString&?dict,?wxLongLong&?id);
????
int?InsertResultTable(const?wxLongLong&?wordid,?const?wxLongLong&?dictid,?const?TResultPair&?result);

????WordClass?GetWordClass(
const?wxString&?type)?const;

????
int?RemoveWordTable(const?wxString&?word,?wxLongLong&?id);
????
int?RemoveResultTable(const?wxLongLong&?wordid);

????
int?SearchWordTable(TRecordData&?record,?wxLongLong&?id);
????
int?SearchResultTable(const?wxLongLong&?wordid,?TRecordData&?record);
????
const?wxString?SearchDictTable(const?wxLongLong&?dictid);
protected:
????wxString?_strDBFile;

????wxSQLite3Database?_DB;
}
;

#include?<map>

#include?
"wx/wx.h"

#include?
"DBAccess.h"


const?wxString?CDBAccess::TABLENAME_WORD????????????=????_("WordTable");
const?wxString?CDBAccess::TABLENAME_DICTIONARY????????=????_("DictionaryTable");
const?wxString?CDBAccess::TABLENAME_RESULT????????????=????_("ResultTable");

const?wxString?CDBAccess::WORDCLASS_NOUN????????????=????_("n.");

CDBAccess::CDBAccess()
{
}


CDBAccess::
~CDBAccess()
{
????Close();
}


int?CDBAccess::Init(const?wxString?&dbfile)
{
????
try
????
{
????????Close();

????????_DB.Open(dbfile);
????????
if(InitTables()?!=?0)
????????????
return?-1;
????}

????
catch(const?wxSQLite3Exception&?e)
????
{
????????
return?-1;
????}

????
return?0;
}


int?CDBAccess::InitTables()
{
????
try
????
{
????????
const?char*?wordtable?=?"CREATE?TABLE?IF?NOT?EXISTS?WordTable?(ID?INTEGER?PRIMARY?KEY?AUTOINCREMENT,Word?VARCHAR(32)?UNIQUE,Symbol?VARCHAR(64),HTML?TEXT,UpdateTime?DATE)";
????????_DB.ExecuteUpdate(wordtable);
????????
const?char*?dicttable?=?"CREATE?TABLE?IF?NOT?EXISTS?DictionaryTable?(ID?INTEGER?PRIMARY?KEY?AUTOINCREMENT,Title?VARCHAR(64),UpdateTime?DATE)";
????????_DB.ExecuteUpdate(dicttable);
????????
const?char*?resulttable?=?"CREATE?TABLE?IF?NOT?EXISTS?ResultTable?(WordID?INTEGER,DictID?INTEGER,ClassID?INTEGER,Result?VARCHAR(255))";
????????_DB.ExecuteUpdate(resulttable);
????}

????
catch(const?wxSQLite3Exception&?e)
????
{
????????
return?-1;
????}
????

????
return?0;
}


void?CDBAccess::Close()
{
????
if(_DB.IsOpen())
????????_DB.Close();
}



int?CDBAccess::Insert(const?CDBAccess::TRecordData?&record)
{
????
try
????
{
????????_DB.Begin();

????????wxLongLong?wordid?
=?0;
????????InsertWordTable(record,?wordid);
????????
for(TRecordVector::const_iterator?it?=?record.m_vctResult.begin();?it?!=?record.m_vctResult.end();?++?it)
????????
{
????????????wxLongLong?dictid?
=?0;
????????????InsertDictTable(it
->first,?dictid);
????????????
for(TResultVector::const_iterator?i?=?it->second.begin();?i?!=?it->second.end();?++?i)
????????????
{
????????????????InsertResultTable(wordid,?dictid,?
*i);
????????????}

????????}


????????_DB.Commit();
????}

????
catch(const?wxSQLite3Exception&?e)
????
{
????????_DB.Rollback();
????????
return?-1;
????}

????
return?0;
}


int?CDBAccess::InsertWordTable(const?CDBAccess::TRecordData?&record,?wxLongLong?&id)
{
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("SELECT?ROWID?FROM?WordTable?WHERE?Word?=??");
????query.Bind(
1,?record.m_strWord);
????wxSQLite3ResultSet?res?
=?query.ExecuteQuery();
????
if(!res.IsOk())
????????
throw?wxSQLite3Exception(255,?_("SELECT?ROWID?of?WordTable?FAILED."));
????
if(!res.Eof())
????
{
????????id?
=?res.GetInt64(0);
????}

????
else
????
{
????????wxSQLite3Statement?query?
=?_DB.PrepareStatement("INSERT?INTO?WordTable?VALUES(NULL,??,??,??,?DATETIME('NOW',?'LOCALTIME'))");
????????query.Bind(
1,?record.m_strWord);
????????query.Bind(
2,?record.m_strSymbol);
????????query.Bind(
3,?record.m_strHTML);
????????query.ExecuteUpdate();

????????id?
=?_DB.GetLastRowId();
????}


????
return?0;
}


int?CDBAccess::InsertDictTable(const?wxString&?dict,?wxLongLong?&id)
{
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("SELECT?ROWID?FROM?DictionaryTable?WHERE?Title?=??");
????query.Bind(
1,?dict);
????wxSQLite3ResultSet?res?
=?query.ExecuteQuery();
????
if(!res.IsOk())
????????
throw?wxSQLite3Exception(255,?_("SELECT?ROWID?of?DictTable?FAILED."));
????
if(!res.Eof())
????
{
????????id?
=?res.GetInt64(0);
????}

????
else
????
{
????????wxSQLite3Statement?query?
=?_DB.PrepareStatement("INSERT?INTO?DictionaryTable?VALUES(NULL,??,?DATETIME('NOW',?'LOCALTIME'))");
????????query.Bind(
1,?dict);
????????query.ExecuteUpdate();

????????id?
=?_DB.GetLastRowId();
????}


????
return?0;
}


int?CDBAccess::InsertResultTable(const?wxLongLong?&wordid,?const?wxLongLong?&dictid,?const?TResultPair&?result)
{
//????WordClass?type?=?GetWordClass(result.first);
????
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("INSERT?INTO?ResultTable?VALUES(?,??,??,??)");
????query.Bind(
1,?wordid);
????query.Bind(
2,?dictid);
????query.Bind(
3,?result.first);
????query.Bind(
4,?result.second);
????query.ExecuteUpdate();????

????
return?0;
}


CDBAccess::WordClass?CDBAccess::GetWordClass(
const?wxString?&type)?const
{
????
if(type?==?WORDCLASS_NOUN)
????????
return?WC_NOUN;
????
else
????????
return?WC_UNKNOWN;
}


int?CDBAccess::Remove(const?wxString?&word)
{
????
try
????
{
????????_DB.Begin();
????????
????????wxLongLong?wordid?
=?0;
????????RemoveWordTable(word,?wordid);
????????RemoveResultTable(wordid);

????????_DB.Commit();
????}

????
catch(const?wxSQLite3Exception&?e)
????
{
????????_DB.Rollback();
????????
return?-1;
????}

????
return?0;
}


int?CDBAccess::RemoveWordTable(const?wxString?&word,?wxLongLong?&id)
{
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("SELECT?ROWID?FROM?WordTable?WHERE?Word?=??");
????query.Bind(
1,?word);
????wxSQLite3ResultSet?res?
=?query.ExecuteQuery();
????
if(!res.IsOk())
????????
throw?wxSQLite3Exception(255,?_("SELECT?ROWID?of?WordTable?FAILED."));
????
if(!res.Eof())
????
{
????????id?
=?res.GetInt64(0);

????????wxSQLite3Statement?query?
=?_DB.PrepareStatement("DELETE?FROM?WordTable?WHERE?ID?=??");
????????query.Bind(
1,?id);????????
????????query.ExecuteUpdate();
????}

????
else
????
{
????????
throw?wxSQLite3Exception(254,?_("SELECT?WordTable?FAILED."));
????}


????
return?0;
}


int?CDBAccess::RemoveResultTable(const?wxLongLong?&wordid)
{
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("DELETE?FROM?ResultTable?WHERE?WordID?=??");
????query.Bind(
1,?wordid);????????
????query.ExecuteUpdate();

????
return?0;
}


int?CDBAccess::Search(CDBAccess::TRecordData?&record)
{
????
try
????
{
????????wxLongLong?wordid?
=?0;
????????SearchWordTable(record,?wordid);
????????SearchResultTable(wordid,?record);
????}

????
catch(const?wxSQLite3Exception&?e)
????
{
????????
return?-1;
????}

????
return?0;
}


int?CDBAccess::SearchWordTable(TRecordData&?record,?wxLongLong?&id)
{
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("SELECT?ROWID,Symbol?FROM?WordTable?WHERE?Word?=??");
????query.Bind(
1,?record.m_strWord);
????wxSQLite3ResultSet?res?
=?query.ExecuteQuery();
????
if(!res.IsOk())
????????
throw?wxSQLite3Exception(255,?_("SELECT?ROWID?of?WordTable?FAILED."));
????
if(!res.Eof())
????
{
????????id?
=?res.GetInt64(0);
????????record.m_strSymbol?
=?res.GetAsString(1);
????}

????
else?
????
{
????????
throw?wxSQLite3Exception(254,?_("SELECT?WordTable?FAILED."));
????}


????
return?0;
}


int?CDBAccess::SearchResultTable(const?wxLongLong&?wordid,?CDBAccess::TRecordData&?record)
{
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("SELECT?DictID,?ClassID,?Result?FROM?ResultTable?WHERE?wordid?=??");
????query.Bind(
1,?wordid);
????wxSQLite3ResultSet?res?
=?query.ExecuteQuery();
????
if(!res.IsOk())
????????
throw?wxSQLite3Exception(255,?_("SELECT?ROWID?of?ResultTable?FAILED."));
????
????std::map
<wxLongLong,?TResultVector>?mapResult;

??????? res.NextRow();//add
????
while(!res.Eof())
????
{
????????wxLongLong?dictid?
=?res.GetInt64(0);
????????std::map
<wxLongLong,?TResultVector>::iterator?it?=?mapResult.find(dictid);
????????
if(it?==?mapResult.end())
????????????it?
=?mapResult.insert(std::make_pair(dictid,?TResultVector())).first;
????????it
->second.push_back(std::make_pair(res.GetInt(1),?res.GetAsString(2)));

????????res.NextRow();
????}


????
for(std::map<wxLongLong,?TResultVector>::const_iterator?it?=?mapResult.begin();?it?!=?mapResult.end();?++?it)
????
{
????????wxString?dict?
=?SearchDictTable(it->first);
????????record.m_vctResult.push_back(std::make_pair(dict,?it
->second));
????}


????
return?0;
}


const?wxString?CDBAccess::SearchDictTable(const?wxLongLong?&dictid)
{
????wxSQLite3Statement?query?
=?_DB.PrepareStatement("SELECT?Title?FROM?DictionaryTable?WHERE?ID?=??");
????query.Bind(
1,?dictid);
????wxSQLite3ResultSet?res?
=?query.ExecuteQuery();
????
if(!res.IsOk())
????????
return?_("FAILED.");
????
if(res.Eof())
????????
return?_("Unknown.");
????
return?res.GetAsString(0);
}


posted on 2009-11-17 18:57 codejie 閱讀(1214) 評論(4)  編輯 收藏 引用 所屬分類: C++

評論

# re: LingosHook:wxSQLite3不錯[未登錄] 2009-11-18 02:08 Liu

損你歸損你,不過我得承認業余時間看看你的blog也是享受,又放松又學習了。

現在你也不上MSN了,好像也就這里能和你聊聊天了  回復  更多評論   

# re: LingosHook:wxSQLite3不錯 2009-11-18 10:07 codejie

@Liu
我也想MSN啊,但現在的環境不像咱們以前啊,這里我就發現不了代理啊。上班對著電腦,一句話不說對我也是折磨啊,好懷念那時一起‘飛揚跋扈’的上班時光。。。
不過咱們MSN聊什么呢?技術?上班夠無聊的了;MM?年紀都一大把了;小孩?咱們男女不同,用的尿片都不一樣啊。。。你說,咱們除了互相詆毀之外,似乎也沒別的要說了,嘿嘿。。。

另:
我打算收你的閱讀費,不過分吧。。。。  回復  更多評論   

# re: LingosHook:wxSQLite3不錯[未登錄] 2009-11-18 14:55 Liu

@codejie

你真是典型的給臉不要臉啊……  回復  更多評論   

# re: LingosHook:wxSQLite3不錯 2009-11-18 16:30 codejie

@Liu
哇哈哈。。。。

你Y是沒睡呢,還是早起呢,還是在給寶寶泡奶呢?這時間好怪啊~咱們時差到底多少啊~別說你Y又跑到火星去了~  回復  更多評論   

公告

Using C++

導航

統計

留言簿(73)

隨筆分類(513)

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧洲一区二区三区久久| 欧美一级专区| 亚洲图片欧洲图片日韩av| 国内免费精品永久在线视频| 国产精品久久久久久久久久久久久久 | 久久男人av资源网站| 久久国产福利| 久久综合色播五月| 免费短视频成人日韩| 欧美韩日高清| 日韩亚洲欧美一区| 亚洲制服少妇| 久久综合精品国产一区二区三区| 久久久久成人精品免费播放动漫| 久久精品国产69国产精品亚洲 | 欧美激情91| 亚洲精一区二区三区| 中日韩美女免费视频网址在线观看 | 久久精品国产欧美激情| 久久激情综合网| 欧美大胆人体视频| 国产精品视频免费| 在线精品一区二区| 亚洲小少妇裸体bbw| 欧美一区二区视频网站| 免费在线国产精品| 国产乱码精品一区二区三| 久久综合网hezyo| 亚洲二区三区四区| 日韩五码在线| 欧美有码在线视频| 欧美大秀在线观看| 中文一区二区| 久久一区视频| 国产精品免费观看在线| 亚洲第一区在线观看| 亚洲午夜免费福利视频| 久久久久久亚洲精品不卡4k岛国| 欧美福利视频在线| 午夜精品久久久久影视| 美女性感视频久久久| 国产精品丝袜91| 99国产精品久久久| 久久综合国产精品台湾中文娱乐网 | 国产精品亚洲不卡a| 亚洲国产成人91精品| 欧美在线视频导航| 日韩视频不卡中文| 免费视频一区| 激情综合在线| 久久国产乱子精品免费女| 亚洲免费成人av| 欧美成人精品三级在线观看 | 老司机免费视频一区二区三区| 欧美午夜精品| 亚洲人成人一区二区在线观看| 久久av在线看| 午夜精品久久久久久久久久久久久| 欧美精品一区二区三区蜜桃 | 国产精品久久久久久久午夜片 | 欧美性一区二区| 国内精品久久久久久久影视麻豆| 亚洲免费在线观看视频| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲电影成人| 久久精品成人一区二区三区蜜臀| 亚洲日本精品国产第一区| 免费看亚洲片| 亚洲精品久久久久久久久久久久 | 韩国在线视频一区| 久久久99爱| 久久国产精品久久w女人spa| 国产日韩欧美在线播放不卡| 亚洲欧美日韩系列| 亚洲自拍偷拍麻豆| 国产小视频国产精品| 久久精品一区| 久久人人97超碰精品888| 在线欧美电影| 亚洲国产一区二区a毛片| 欧美大片在线看| 9久草视频在线视频精品| 日韩性生活视频| 国产精品久久网| 久久久之久亚州精品露出| 久久久久久久波多野高潮日日| 亚洲福利专区| av成人天堂| 国产亚洲精品成人av久久ww| 久久久久久综合网天天| 久久亚洲风情| 亚洲午夜一区二区三区| 欧美一区二区三区久久精品茉莉花| 国内精品**久久毛片app| 欧美激情一二三区| 国产精品国产一区二区| 久久久久久亚洲精品杨幂换脸| 免费观看成人www动漫视频| 一区二区三区国产在线| 先锋影院在线亚洲| 亚洲欧洲在线播放| 中文精品99久久国产香蕉| 极品少妇一区二区| 亚洲精品在线免费观看视频| 国产日韩欧美在线播放不卡| 亚洲国产专区校园欧美| 国产亚洲成av人片在线观看桃 | 亚洲午夜免费福利视频| 狠狠爱综合网| 一区二区三区欧美日韩| 激情欧美亚洲| 亚洲无亚洲人成网站77777| 在线日韩中文| 亚洲尤物在线视频观看| 91久久在线播放| 欧美亚洲免费| 亚洲一区欧美激情| 欧美成人国产| 欧美h视频在线| 国产午夜精品视频| 中文欧美字幕免费| 日韩小视频在线观看| 久久久国产精彩视频美女艺术照福利| 夜夜嗨av一区二区三区免费区| 欧美在线观看日本一区| 亚洲自拍偷拍福利| 欧美久久久久久| 欧美黑人国产人伦爽爽爽| 国产一区二区日韩精品欧美精品| 亚洲美女视频在线观看| 亚洲激情视频在线| 久久久久久精| 亚洲欧洲精品一区二区三区不卡| 午夜精品视频在线| 亚洲专区一区| 欧美三级精品| 亚洲精品自在久久| 一本久久精品一区二区| 免费亚洲电影| 亚洲成人在线视频播放| 亚洲国产精品成人| 老司机aⅴ在线精品导航| 狼人社综合社区| 在线成人中文字幕| 久久综合成人精品亚洲另类欧美 | 欧美一区二区性| 国产伦精品一区二区三区高清版| 在线一区观看| 亚洲欧美日韩中文播放| 国产精品性做久久久久久| 亚洲一区二区在| 欧美在线视频在线播放完整版免费观看| 欧美日韩精品免费观看| 99国产精品久久久久久久久久| 日韩亚洲在线| 欧美日韩免费网站| 亚洲视频在线看| 久久经典综合| 亚洲高清不卡av| 欧美激情综合网| 一区二区三区国产在线| 欧美一区二区三区在线观看视频 | 亚洲精品乱码久久久久久| 国产精品99久久久久久有的能看| 欧美日韩裸体免费视频| 亚洲一区二区网站| 久久久久久穴| 亚洲精品免费看| 国产精品sm| 欧美在线视频全部完| 欧美二区在线看| 亚洲一区二区三区免费观看| 国产精品揄拍一区二区| 久久综合九色| 一区二区三区高清在线| 久久久久久久综合色一本| 91久久中文字幕| 国产精品久久久久久久一区探花| 久久精品1区| 亚洲精品一区二区在线观看| 欧美一级网站| 亚洲精品乱码久久久久久久久| 欧美性猛交一区二区三区精品| 欧美在线综合视频| 亚洲美女少妇无套啪啪呻吟| 久久久久99| 亚洲一区二区精品| 亚洲国产精品久久人人爱蜜臀 | 久热精品视频在线观看一区| 一本色道**综合亚洲精品蜜桃冫| 久久爱www.| 在线亚洲+欧美+日本专区| 国语自产精品视频在线看8查询8| 欧美巨乳在线| 久久人91精品久久久久久不卡 | 亚洲精品综合| 久久久久免费视频| 亚洲美女精品一区| 激情综合自拍| 国产欧美在线视频|