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

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 閱讀(1226) 評論(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>
            国产一区999| 一区二区三区高清| 亚洲精品小视频在线观看| 欧美成人免费在线视频| 亚洲精品美女久久久久| 在线亚洲自拍| 国产欧美一区二区在线观看| 欧美在线视频不卡| 欧美国产先锋| 亚洲免费一在线| 伊人男人综合视频网| 欧美寡妇偷汉性猛交| 亚洲午夜电影在线观看| 久久久久高清| 日韩午夜电影| 国产视频观看一区| 欧美第十八页| 亚洲欧美日本精品| 欧美国产精品日韩| 午夜老司机精品| 亚洲高清视频的网址| 国产精品久久久久久久7电影 | 欧美成人国产一区二区| 日韩午夜精品视频| 久久―日本道色综合久久| 99在线|亚洲一区二区| 国产日韩精品一区二区三区| 欧美电影专区| 久久精品国亚洲| 99精品99久久久久久宅男| 蜜桃av噜噜一区二区三区| 亚洲系列中文字幕| 亚洲高清一区二区三区| 国产欧美精品国产国产专区| 久久久91精品国产| 日韩亚洲精品在线| 精品动漫3d一区二区三区| 国产精品国产三级国产专播精品人 | 欧美午夜片欧美片在线观看| 欧美在线观看日本一区| aⅴ色国产欧美| 亚洲第一中文字幕在线观看| 久久国产欧美精品| 亚洲永久免费精品| 亚洲精品永久免费精品| 激情久久婷婷| 国产私拍一区| 国产精品视频最多的网站| 欧美成人免费在线视频| 久久久亚洲午夜电影| 亚洲欧美偷拍卡通变态| 亚洲午夜精品17c| 日韩视频亚洲视频| 亚洲全黄一级网站| 亚洲国产女人aaa毛片在线| 久久久久久自在自线| 欧美伊人久久大香线蕉综合69| 一区二区三区精品视频| 亚洲欧洲一区二区天堂久久| 精品成人久久| 黄色工厂这里只有精品| 国产一区二区三区最好精华液| 国产乱码精品1区2区3区| 国产精品99免费看 | 亚洲日韩成人| 亚洲国产裸拍裸体视频在线观看乱了 | 久久精品国产一区二区三区| 先锋资源久久| 欧美与欧洲交xxxx免费观看 | 国产亚洲欧美日韩精品| 国产精品性做久久久久久| 国产精品久久久久久久久免费樱桃 | 久久久久天天天天| 久久夜色精品| 免费中文日韩| 欧美激情一二区| 91久久极品少妇xxxxⅹ软件| 亚洲高清视频的网址| 亚洲黄色一区| 99成人在线| 亚洲一区久久久| 欧美一区二区三区电影在线观看| 欧美亚洲自偷自偷| 久久精品国产69国产精品亚洲| 久久精品人人做人人爽| 免费成人性网站| 欧美久久久久久久久久| 欧美午夜精品久久久久免费视| 国产精品视屏| 伊人精品成人久久综合软件| 亚洲黄色在线视频| 老巨人导航500精品| 免费国产一区二区| 欧美特黄一级大片| 国产视频在线观看一区二区| 激情久久久久久久久久久久久久久久| 亚洲国产电影| 亚洲网站啪啪| 久久色在线播放| 亚洲国内自拍| 亚洲一区二区在线| 久久婷婷久久| 欧美三级电影大全| 国产一区二区三区日韩欧美| 亚洲日本无吗高清不卡| 亚洲欧美日韩精品久久奇米色影视| 欧美一区二区三区四区夜夜大片| 欧美v国产在线一区二区三区| 亚洲肉体裸体xxxx137| 亚洲欧美国产77777| 美女视频网站黄色亚洲| 国产精品视频第一区| 亚洲国产成人午夜在线一区| 亚洲一区二区三区四区五区午夜| 久久久久久久欧美精品| 亚洲裸体视频| 久久久久9999亚洲精品| 欧美体内she精视频| 在线观看中文字幕不卡| 亚洲午夜在线| 亚洲第一福利在线观看| 亚洲专区一二三| 欧美精品一区二区三区四区 | 狠狠色丁香久久婷婷综合_中| 日韩午夜电影av| 久久久久高清| 亚洲小视频在线观看| 欧美ab在线视频| 国内揄拍国内精品少妇国语| 亚洲视频精选在线| 欧美国产三区| 久久国产精品电影| 国产精品老牛| 中日韩男男gay无套| 欧美电影免费观看网站| 欧美亚洲日本网站| 国产精品大片wwwwww| 亚洲高清中文字幕| 久久人人九九| 午夜视频一区二区| 国产精品国产馆在线真实露脸| 亚洲精选91| 欧美激情一区二区三区高清视频 | 久久九九久久九九| 国产欧美激情| 香港久久久电影| 99精品视频免费全部在线| 你懂的国产精品| 亚洲国产国产亚洲一二三| 六月婷婷一区| 欧美在线播放| 国产婷婷色一区二区三区在线| 亚洲欧美日韩精品在线| 一区二区欧美在线观看| 欧美美女bb生活片| 999在线观看精品免费不卡网站| 欧美激情成人在线视频| 麻豆91精品| 最新高清无码专区| 亚洲国产成人久久综合| 欧美福利专区| 99精品免费视频| 99亚洲视频| 国产精品久久久久久久久果冻传媒| 在线视频欧美日韩精品| 99国产精品久久久久久久| 欧美日韩中文字幕日韩欧美| 亚洲性线免费观看视频成熟| 99国产精品私拍| 国产精品免费一区二区三区在线观看| 亚洲欧美日韩国产中文在线| 亚洲视频导航| 国产一级精品aaaaa看| 久久综合99re88久久爱| 久久综合色影院| 99精品国产高清一区二区 | 国产精品视频成人| 久久精品女人| 美女精品在线观看| 一区二区三区欧美成人| 亚洲视频精选| 国内成+人亚洲+欧美+综合在线| 久久阴道视频| 欧美激情免费观看| 亚洲欧美日韩一区二区在线 | 亚洲小少妇裸体bbw| 国产亚洲精品高潮| 欧美国产在线视频| 欧美日韩视频在线一区二区观看视频 | 精品51国产黑色丝袜高跟鞋| 欧美不卡一卡二卡免费版| 欧美日本国产精品| 久久国产加勒比精品无码| 久久亚洲不卡| 亚洲在线观看免费| 久久精彩免费视频| 一级成人国产| 久久久国产精品亚洲一区| 妖精视频成人观看www| 欧美影院久久久|