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

流量統計:
Rixu Blog (日需博客)
日需博客,每日必需來踩踩哦..
posts - 108,comments - 54,trackbacks - 0
Here you can see some examples.
It shows a part of the functionality of the wrapper and how you can use it.
You can find more examples in the example application (contained in download package). 


1. open a database and create a statement instance for sql queries/statements
  1. // open database
  2. Kompex::SQLiteDatabase *pDatabase = new Kompex::SQLiteDatabase("test.db", SQLITE_OPEN_READWRITE, 0);
  3. // create statement instance for sql queries/statements
  4. Kompex::SQLiteStatement *pStmt = new Kompex::SQLiteStatement(pDatabase);


2. create a new table and fill it with data
  1. // create table and insert some data
  2. pStmt->SqlStatement("CREATE TABLE user                        \
  3.                     (                                         \
  4.                     userID INTEGER NOT NULL PRIMARY KEY,      \
  5.                     lastName VARCHAR(50) NOT NULL,            \
  6.                     firstName VARCHAR(50), age INTEGER        \
  7.                     )");
  8.                     
  9. pStmt->SqlStatement("INSERT INTO user (userID, lastName, firstName, age) \
  10.                      VALUES (1, 'Lehmann', 'Jamie', 20)");
  11. pStmt->SqlStatement("INSERT INTO user (userID, lastName, firstName, age) \
  12.                      VALUES (2, 'Burgdorf', 'Peter', 55)");
  13. pStmt->SqlStatement("INSERT INTO user (userID, lastName, firstName, age) \
  14.                      VALUES (3, 'Lehmann', 'Fernando', 18)");
  15. pStmt->SqlStatement("INSERT INTO user (userID, lastName, firstName, age) \
  16.                      VALUES (4, 'Lehmann', 'Carlene', 17)");


3. use some aggregate functions
  1. pStmt->SqlAggregateFuncResult("SELECT COUNT(*) FROM user WHERE lastName = 'Lehmann';");
  2. pStmt->SqlAggregateFuncResult("SELECT COUNT(weight) FROM user;");
  3. pStmt->SqlAggregateFuncResult("SELECT MAX(age) FROM user;");
  4. pStmt->SqlAggregateFuncResult("SELECT MIN(age) FROM user;");
  5. pStmt->SqlAggregateFuncResult("SELECT AVG(age) FROM user;");
  6. pStmt->SqlAggregateFuncResult("SELECT SUM(age) FROM user;");
  7. pStmt->SqlAggregateFuncResult("SELECT TOTAL(age) FROM user;");


4. execute and process a sql query
  1. pStmt->Sql("SELECT * FROM user WHERE firstName = 'Jamie';");
  2. // process all results
  3. while(pStmt->FetchRow())
  4. {
  5.     std::cout << "first name: " << pStmt->GetColumnInt(0) << std::endl;
  6.     std::cout << "last name: " << pStmt->GetColumnString(1) << std::endl;
  7.     std::cout << "first name: " << pStmt->GetColumnString(2) << std::endl;
  8. }
  9. // do not forget to clean-up
  10. pStmt->FreeQuery();


5. execute a simple transaction
  1. // if an error occurs, a rollback is automatically performed
  2. pStmt->BeginTransaction();
  3. pStmt->Transaction("INSERT INTO user(userID, firstName, age) VALUES (10, 'Makoto', 23)");
  4. pStmt->Transaction("INSERT INTO user(userID, firstName, age) VALUES (11, 'Yura', 20)";
  5. pStmt->Transaction("INSERT INTO user(userID, firstName, age) VALUES (12, 'Peter', 63)");
  6. pStmt->CommitTransaction();


6. here you can see the exception handling
  1. try
  2. {
  3.     // table structure: userID INTEGER NOT NULL PRIMARY KEY, lastName VARCHAR(50)
  4.     pStmt->SqlStatement("INSERT INTO user(userID, lastName) VALUES(1, 'Lehmann')");
  5.     // the following line will throw an exception because the primary key is not unique
  6.     pStmt->SqlStatement("INSERT INTO user(userID, lastName) VALUES(1, 'Bergmann')");
  7. }
  8. catch(Kompex::SQLiteException &exception)
  9. {
  10.     std::cerr << "Exception Occured" << std::endl;
  11.     exception.Show();
  12. }


7. work with a memory database
  1. Kompex::SQLiteDatabase *pDatabase = new Kompex::SQLiteDatabase("scores.db", SQLITE_OPEN_READWRITE, 0);
  2. // move database to memory, so that we are work on the memory database hence
  3. pDatabase->MoveDatabaseToMemory();
  4.  
  5. Kompex::SQLiteStatement *pStmt = new Kompex::SQLiteStatement(pDatabase);
  6. // insert some data sets into the memory database
  7. pStmt->SqlStatement("INSERT INTO score(id, lastScore, avgScore) VALUES(1, 429, 341)");
  8. pStmt->SqlStatement("INSERT INTO score(id, lastScore, avgScore) VALUES(2, 37, 44)");
  9. pStmt->SqlStatement("INSERT INTO score(id, lastScore, avgScore) VALUES(3, 310, 280)");
  10.  
  11. // save the memory database to a file
  12. // if you don't do it, all database changes will be lost after closing the memory database
  13. pDatabase->SaveDatabaseFromMemoryToFile("newScores.db");


8. get some result values via column name (more flexible and a little bit slower than the common way)
  1. pStmt->Sql("SELECT * FROM user WHERE lastName = 'Lehmann';");
  2.  
  3. // process all results
  4. while(pStmt->FetchRow())
  5. {
  6.     std::cout << "firstName: " << pStmt->GetColumnString("firstName") << std::endl;
  7.     std::cout << "age: " << pStmt->GetColumnInt("age") << std::endl;
  8. }
  9.  
  10. // do not forget to clean-up
  11. pStmt->FreeQuery();    


9. two possibilities to update data in the database
  1. // the first way
  2. pStmt->SqlStatement("UPDATE user SET weight=51.5, age=18 WHERE firstName='Carlene'");
  3.         
  4. // the second way - with a prepared statement
  5. pStmt->Sql("UPDATE user SET lastName=@lastName, age=@age WHERE userID=@userID");
  6.             
  7. // bind an integer to the prepared statement
  8. pStmt->BindString(1, "Urushihara");        // bind lastName
  9. pStmt->BindInt(2, 56);                    // bind age
  10. pStmt->BindInt(3, 2);                    // bind userID
  11.  
  12. // execute it and clean-up
  13. pStmt->ExecuteAndFree();
Logo
作者:Gezidan
出處:http://www.rixu.net    
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
posted on 2011-08-02 14:12 日需博客 閱讀(1778) 評論(1)  編輯 收藏 引用 所屬分類: C C++ 、技術文章 、轉載

FeedBack:
# re: Kompex SQLite Wrapper for C++ - Examples
2012-09-21 18:09 | czp
你把別網站上的代碼拷貝過來,有意思嗎?  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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在线观看精品免费不卡网站| 99视频一区| 国产一区二区三区精品久久久 | 欧美激情1区2区| 亚洲午夜免费福利视频| 久久www成人_看片免费不卡| 国内精品久久久久影院薰衣草 | 欧美xx69| 亚洲一区欧美| 欧美成人免费一级人片100| 一个人看的www久久| 欧美肉体xxxx裸体137大胆| 欧美在线视频播放| 亚洲美女视频在线观看| 久久男人资源视频| 亚洲在线视频网站| 91久久精品一区二区三区| 国产精品一区二区你懂的| 欧美福利一区二区三区| 亚洲欧美日韩综合国产aⅴ| 欧美激情一区二区三区| 久久精品三级| 久久国产加勒比精品无码| 亚洲午夜激情网站| 99国内精品| 久久夜色精品国产噜噜av| 午夜在线成人av| 中文国产成人精品久久一| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲国产一区二区三区高清| 久久精品国产清自在天天线| 亚洲欧美久久久久一区二区三区| 最近中文字幕mv在线一区二区三区四区| 国产精品一区三区| 国产女主播在线一区二区| 国产精品裸体一区二区三区| 欧美性视频网站| 国产精品毛片一区二区三区| 国产精品a久久久久久| 国产精品第一区| 国产视频一区欧美| 极品裸体白嫩激情啪啪国产精品| 精品福利av| 亚洲欧洲精品一区二区三区| 亚洲精品永久免费精品| 一二三四社区欧美黄| 久久福利一区| 亚洲大片在线观看| 亚洲一二三四区| 久久国产日韩| 欧美日韩中字| 亚洲国产成人在线播放| 亚洲视频免费观看| 麻豆精品视频| 亚洲欧美激情在线视频| 欧美mv日韩mv国产网站| 国产美女精品人人做人人爽| 在线日韩av永久免费观看| 亚洲香蕉网站| 欧美黑人国产人伦爽爽爽| 欧美伊人久久| 亚洲电影免费观看高清| 午夜久久影院| 国产精品久久久久久久久久三级| 在线成人国产| 久久九九电影| 亚洲一区影音先锋| 欧美日韩一区在线| 亚洲日本视频| 欧美激情视频网站| 久久综合国产精品台湾中文娱乐网| 欧美三级欧美一级| av不卡免费看| 亚洲精品国产精品乱码不99按摩| 美女精品在线观看| 在线看一区二区| 麻豆国产精品va在线观看不卡| 亚洲综合三区| 国产日韩亚洲欧美综合| 亚洲欧美日韩在线综合| 亚洲午夜久久久久久久久电影院| 欧美午夜理伦三级在线观看| 亚洲图片在线观看| 亚洲欧美在线观看| 国产午夜精品理论片a级探花| 久久国产精品99国产精| 久久av一区二区三区亚洲| 在线观看国产欧美| 亚洲国产日韩欧美在线99| 欧美日韩免费精品| 久久精品国产欧美激情| 欧美www在线| 欧美亚洲专区| 嫩草国产精品入口| 亚洲女同同性videoxma| 欧美在线播放视频| 亚洲精品美女在线观看播放| 日韩视频免费观看高清在线视频| 国产精品亚洲综合久久| 亚洲福利免费| 国产农村妇女精品| 亚洲国产精品高清久久久| 国产精品免费一区二区三区观看| 老**午夜毛片一区二区三区| 欧美日韩999| 欧美激情中文不卡| 久久久久一区| 亚洲女与黑人做爰| 美日韩精品视频| 久久精品一区二区三区不卡牛牛| 欧美福利在线| 久久综合精品国产一区二区三区| 久久久福利视频| 国产精品欧美激情| 亚洲视频精品在线| 欧美日产一区二区三区在线观看| 久久精品国产亚洲5555| 欧美日韩另类字幕中文| 亚洲成色最大综合在线| 亚洲成人中文| 蜜桃久久精品乱码一区二区| 久久狠狠婷婷| 精品51国产黑色丝袜高跟鞋| 欧美一区二区视频在线观看2020| 欧美亚洲一区在线| 国产日韩免费| 久久久久国产一区二区三区| 久久综合999| 亚洲欧美日韩在线观看a三区| 在线看日韩欧美| 欧美成人精品一区二区三区| 亚洲国产综合91精品麻豆| 日韩一二三区视频| 欧美性做爰毛片| 篠田优中文在线播放第一区| 欧美一区三区二区在线观看| 国产日韩欧美视频在线| 久久理论片午夜琪琪电影网| 久久亚洲一区| 影视先锋久久| 美日韩精品视频| 一本色道久久综合| 西西人体一区二区| 欧美精品一区在线观看| 日韩视频中文字幕| 久久免费的精品国产v∧| 亚洲最新中文字幕| 红桃av永久久久| 国产精品系列在线播放| 久久综合精品一区| 亚洲亚洲精品在线观看| 亚洲国产成人精品女人久久久| 免费观看成人鲁鲁鲁鲁鲁视频| 99re66热这里只有精品4| 国产精品理论片在线观看| 极品尤物一区二区三区| 欧美日韩卡一卡二| 免费观看一级特黄欧美大片| 久久久精品视频成人| 欧美国产精品久久| 久久久久久久精| 久久99伊人| 欧美亚洲网站| 欧美一区二区三区日韩视频| 99精品欧美一区二区三区| 激情av一区| 伊人久久久大香线蕉综合直播| 国产欧美日韩亚洲| 国产私拍一区| 国内成人精品2018免费看| 国产视频综合在线| 狠狠做深爱婷婷久久综合一区| 韩国女主播一区二区三区| 国内精品**久久毛片app| 国内揄拍国内精品少妇国语| 狠狠色丁香婷婷综合影院| 亚洲电影免费观看高清完整版在线观看 | 欧美成va人片在线观看| 麻豆成人在线| 欧美日韩中字| 国产一区二区高清| 一区二区在线看| 日韩写真在线| 欧美在线地址| 亚洲激情一区二区| 亚洲先锋成人| 欧美成人a视频| 国产精品中文字幕在线观看| 亚洲第一精品夜夜躁人人爽| 一区二区三区视频在线|