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

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>
            亚洲国内高清视频| 亚洲一区二区三区高清 | 欧美激情视频一区二区三区免费| 亚洲影院高清在线| 午夜视频在线观看一区二区三区| 欧美一区国产一区| 久久riav二区三区| 久久免费视频在线观看| 欧美成人免费小视频| 亚洲黄色av一区| 99视频日韩| 亚洲欧美日韩精品在线| 久久久久久亚洲精品杨幂换脸 | 国产精品久久亚洲7777| 国产日韩在线视频| 亚洲国产成人av在线| 一区二区三区高清在线| 性伦欧美刺激片在线观看| 久久综合网hezyo| 亚洲精品一区久久久久久| 亚洲图片欧美日产| 美脚丝袜一区二区三区在线观看 | 老妇喷水一区二区三区| 亚洲人成小说网站色在线| 在线中文字幕一区| 麻豆国产精品一区二区三区| 欧美午夜片在线观看| 在线免费观看日本一区| 亚洲一区网站| 久久综合中文色婷婷| 一区二区三区精品| 久久天天综合| 国产欧美日韩91| 亚洲深夜福利| 欧美激情按摩| 久久久久九九视频| 国产欧美一区二区三区沐欲| 亚洲精品乱码久久久久久日本蜜臀| 在线中文字幕日韩| 欧美成人免费视频| 欧美专区亚洲专区| 国产日韩欧美视频| 久久成人精品电影| 欧美激情一区二区三区不卡| 亚洲男人av电影| 欧美午夜视频| 一本色道久久88综合日韩精品| 久久久噜噜噜久久久| 亚洲一区一卡| 国产精品黄色在线观看| 宅男噜噜噜66一区二区| 欧美激情第3页| 久久久久成人精品免费播放动漫| 国产精品丝袜xxxxxxx| 亚洲一卡久久| av成人免费| 国产精品xnxxcom| 一本高清dvd不卡在线观看| 欧美福利电影网| 久久婷婷国产综合尤物精品| 国内久久视频| 久久久99免费视频| 久久精品亚洲乱码伦伦中文| 国产一区二区成人| 久久综合亚州| 久久综合影视| 亚洲精品男同| 一区二区三区波多野结衣在线观看| 欧美欧美午夜aⅴ在线观看| 亚洲精品系列| 亚洲免费精彩视频| 国产精品麻豆va在线播放| 亚洲欧美日韩一区二区在线| 亚洲一卡二卡三卡四卡五卡| 国产精品一级二级三级| 久久九九电影| 乱中年女人伦av一区二区| 亚洲国产精品一区二区www在线| 麻豆久久婷婷| 欧美日韩国产不卡在线看| 亚洲欧美一区在线| 韩国女主播一区| 亚洲国产欧美一区| 国产精品av免费在线观看| 性色av一区二区三区| 久久免费精品日本久久中文字幕| 亚洲国产精品第一区二区三区| 欧美激情一区二区三区高清视频| 欧美日韩调教| 久久嫩草精品久久久精品| 免费在线观看一区二区| 亚洲在线视频网站| 久久久国产精彩视频美女艺术照福利| 亚洲国内高清视频| 一区二区三区四区五区视频| 国产欧美一区二区精品秋霞影院| 欧美v国产在线一区二区三区| 欧美理论在线| 久久久综合激的五月天| 欧美精品一区在线播放| 欧美在线一二三四区| 欧美成人一区二区| 久久国产精品久久精品国产 | 久久久久久一区二区三区| 久久久青草婷婷精品综合日韩| 日韩午夜激情av| 亚洲免费视频成人| 亚洲免费av网站| 久久国产精彩视频| 亚洲免费一区二区| 欧美极品一区二区三区| 久久中文字幕一区| 国产精品三级久久久久久电影| 欧美成人午夜影院| 国产欧美高清| 亚洲一级黄色| 亚洲一区二区高清视频| 蜜桃精品一区二区三区 | 亚洲精品极品| 亚洲国产日韩综合一区| 性亚洲最疯狂xxxx高清| 亚洲综合精品一区二区| 欧美日本簧片| 亚洲黄色尤物视频| 亚洲国产精品视频| 久久精品日韩| 美女久久一区| 尤物yw午夜国产精品视频明星| 亚洲欧美日韩人成在线播放| 亚洲一级黄色片| 欧美日韩一视频区二区| 亚洲日韩欧美视频一区| 亚洲人妖在线| 欧美18av| 亚洲激情第一页| 亚洲欧洲日本一区二区三区| 久久久亚洲影院你懂的| 老司机免费视频久久| 在线日韩精品视频| 久久一区中文字幕| 欧美成人综合网站| 亚洲精品中文字幕在线观看| 欧美激情综合| 亚洲午夜一区二区三区| 欧美在线视频网站| 影音先锋日韩精品| 欧美成人激情视频| 99精品99久久久久久宅男| 亚洲一区日韩| 国产亚洲激情| 免费观看30秒视频久久| 亚洲精品少妇| 欧美综合77777色婷婷| 激情成人av| 欧美激情片在线观看| 在线一区日本视频| 久久激情中文| 亚洲日本在线视频观看| 国产精品xnxxcom| 久久精品成人一区二区三区| 欧美大片免费久久精品三p| 一区二区欧美在线观看| 国产精品一区免费视频| 新狼窝色av性久久久久久| 久久中文字幕一区| 99亚洲精品| 狠狠入ady亚洲精品经典电影| 免费不卡在线视频| 亚洲综合国产激情另类一区| 模特精品在线| 午夜日韩在线| 国产片一区二区| 久久看片网站| 亚洲永久免费精品| 国产精品日韩| 久久精品一区二区三区四区| 亚洲欧美日韩综合aⅴ视频| 国产精品视频免费在线观看| 欧美一区1区三区3区公司| 美腿丝袜亚洲色图| 亚洲欧美自拍偷拍| 免费一级欧美片在线观看| 欧美亚洲日本国产| 欧美伦理91i| 亚洲第一二三四五区| 免费看精品久久片| 男同欧美伦乱| 亚洲二区在线观看| 欧美一二三区精品| 性做久久久久久久久| 国产精品高潮在线| 亚洲精品久久久久久久久久久 | 国产精品成人av性教育| 免费在线视频一区| 最新精品在线| 欧美精品日韩三级| av成人毛片| 久久久不卡网国产精品一区| 国产手机视频一区二区| 欧美在线欧美在线|