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

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 閱讀(1212) 評論(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>
            亚洲国产精品激情在线观看| 美女主播精品视频一二三四| 欧美激情在线有限公司| 亚洲日韩成人| 99ri日韩精品视频| 国产女主播在线一区二区| 久久国产精品99国产| 欧美中在线观看| 亚洲三级色网| 欧美大色视频| 亚洲一区二区三区午夜| 午夜精品成人在线| 亚洲二区在线| 在线一区亚洲| 在线精品观看| 亚洲免费精品| 国产一区二区三区在线免费观看 | 亚洲一二区在线| 亚洲欧美一区二区在线观看| 亚洲国产欧美一区| 亚洲天堂av电影| 亚洲激情国产| 亚洲欧美视频| 亚洲美女中文字幕| 欧美一区二区视频在线观看2020| 亚洲黄色视屏| 午夜视频在线观看一区二区| 亚洲精品国久久99热| 香蕉久久夜色| 亚洲社区在线观看| 久久这里有精品15一区二区三区| 亚洲一区二区四区| 欧美xxxx在线观看| 久久久欧美精品sm网站| 欧美日韩在线观看视频| 欧美成人免费全部观看天天性色| 国产精品系列在线| 99视频有精品| 亚洲欧洲免费视频| 欧美在线一二三区| 午夜精品免费视频| 欧美人与性动交α欧美精品济南到| 欧美在线观看天堂一区二区三区| 欧美美女福利视频| 亚洲国产欧美一区二区三区丁香婷| 91久久午夜| 在线观看日韩| 久久精品国产免费观看| 亚洲欧美一区二区三区极速播放 | 亚洲国产另类久久久精品极度| 欧美一区二区视频在线| 欧美一级二级三级蜜桃| 国产精品hd| 99视频超级精品| 99香蕉国产精品偷在线观看| 欧美 日韩 国产 一区| 久久久欧美精品| 狠狠做深爱婷婷久久综合一区| 亚洲欧美日韩精品久久久久 | 好看的亚洲午夜视频在线| 亚洲一区二区三区精品动漫| 亚洲永久精品大片| 欧美亚日韩国产aⅴ精品中极品| 91久久精品国产91性色| 日韩亚洲在线观看| 欧美人成在线视频| 亚洲毛片播放| 中文网丁香综合网| 欧美系列亚洲系列| 亚洲一区二区伦理| 久久久久网站| 亚洲二区三区四区| 欧美激情一区二区三区蜜桃视频| 亚洲高清在线观看| 亚洲深夜福利网站| 国产欧美日韩精品专区| 久久国产一区二区三区| 欧美成人亚洲成人日韩成人| 91久久久久| 欧美日韩美女一区二区| 亚洲午夜一级| 美女视频黄 久久| 亚洲欧洲日韩综合二区| 欧美视频导航| 欧美中文字幕久久| 91久久精品网| 欧美亚洲日本网站| 精品成人a区在线观看| 欧美高清日韩| 亚洲一区在线免费观看| 免费在线亚洲欧美| 亚洲无线观看| 精品电影一区| 欧美日韩亚洲激情| 欧美一区二区性| 日韩午夜在线观看视频| 欧美影院午夜播放| 亚洲毛片在线免费观看| 国产精品视频一区二区高潮| 久久午夜精品一区二区| 亚洲天堂av电影| 欧美大片免费观看| 午夜精品久久一牛影视| 亚洲激情在线观看视频免费| 国产精品免费在线| 麻豆国产精品va在线观看不卡| 亚洲一区二区欧美日韩| 亚洲高清成人| 久久亚洲综合网| 午夜精品久久久| 最新日韩在线视频| 国产亚洲欧美一区| 久久综合狠狠综合久久激情| 99精品国产在热久久| 极品尤物av久久免费看 | 久久精品国产成人| 亚洲视频精品| 亚洲精品偷拍| 欧美激情久久久| 久久精品国产77777蜜臀| 一区二区三区回区在观看免费视频| 韩国成人理伦片免费播放| 国产精品福利影院| 欧美巨乳在线观看| 欧美a级片一区| 久久乐国产精品| 欧美一区二区女人| 亚洲欧美视频一区| 亚洲欧美中文日韩在线| 亚洲一区二区三区精品动漫| 9国产精品视频| 日韩视频一区二区三区| 亚洲国产天堂久久综合网| 欧美大片一区二区三区| 久久综合精品一区| 久色婷婷小香蕉久久| 麻豆精品在线播放| 噜噜噜91成人网| 麻豆91精品| 噜噜爱69成人精品| 欧美v日韩v国产v| 欧美激情视频一区二区三区在线播放| 久久久精品五月天| 免费国产一区二区| 欧美黑人在线观看| 亚洲狠狠丁香婷婷综合久久久| 欧美激情精品久久久久久变态 | 久久久精品免费视频| 老色鬼久久亚洲一区二区| 麻豆视频一区二区| 欧美激情视频在线免费观看 欧美视频免费一 | 午夜免费日韩视频| 久久久国产视频91| 老牛国产精品一区的观看方式| 久久久国产精品一区二区中文 | 午夜国产精品视频免费体验区| 亚洲免费在线| 久久精品主播| 欧美二区不卡| 国产精品www.| 国产一区二区三区直播精品电影 | 亚洲欧美日韩专区| 久久精品国产亚洲a| 免费在线亚洲欧美| 一区二区欧美日韩| 性8sex亚洲区入口| 男人插女人欧美| 国产精品成人免费视频| 国产一本一道久久香蕉| 亚洲国产天堂久久综合| 亚洲伊人伊色伊影伊综合网| 久久精品国产欧美亚洲人人爽| 久久深夜福利免费观看| 久久久久久69| 欧美久久视频| 国产日韩精品一区二区三区| 亚洲国产欧美国产综合一区| 亚洲视频一起| 久久嫩草精品久久久精品| 亚洲国产老妈| 欧美一级视频一区二区| 欧美激情第9页| 国产区二精品视| 亚洲另类春色国产| 久久精品午夜| 日韩亚洲一区二区| 久久久久青草大香线综合精品| 欧美日韩一区二区三区在线 | 亚洲欧美日韩国产一区二区三区 | 亚洲人成网站影音先锋播放| 亚洲欧美一区二区三区极速播放| 免费欧美日韩国产三级电影| 国产农村妇女精品| 一区二区av在线| 免费欧美电影| 亚洲欧美三级在线| 国产精品va在线播放| 日韩一区二区高清| 免费在线成人av| 午夜在线视频观看日韩17c|