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

流量統(tǒng)計(jì):
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    
本文版權(quán)歸作者和博客園共有,歡迎轉(zhuǎn)載,但未經(jīng)作者同意必須保留此段聲明,且在文章頁(yè)面明顯位置給出原文連接,否則保留追究法律責(zé)任的權(quán)利。
posted on 2011-08-02 14:12 日需博客 閱讀(1787) 評(píng)論(1)  編輯 收藏 引用 所屬分類: C C++技術(shù)文章轉(zhuǎn)載

FeedBack:
# re: Kompex SQLite Wrapper for C++ - Examples
2012-09-21 18:09 | czp
你把別網(wǎng)站上的代碼拷貝過來,有意思嗎?  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 欧美高清视频www夜色资源网| 欧美成人免费一级人片100| 亚洲国产精品电影在线观看| 欧美视频精品一区| 亚洲综合视频网| 欧美激情免费观看| 榴莲视频成人在线观看| 亚洲男人第一av网站| 伊人久久亚洲美女图片| 好看的日韩av电影| 国产精品久久久久久久第一福利| 欧美高清在线播放| 欧美va亚洲va香蕉在线| 亚洲欧美经典视频| 农村妇女精品| 久久精品噜噜噜成人av农村| 欧美一区二区在线免费观看| 亚洲日本成人女熟在线观看| 一区二区三区高清| 欧美日韩国产首页在线观看| 久久成人免费网| 先锋资源久久| 国产亚洲va综合人人澡精品| 性欧美videos另类喷潮| 欧美在线视频网站| 老司机精品视频网站| 亚洲美女视频网| 久久国产精品亚洲77777| 美女爽到呻吟久久久久| 国产精品乱看| 亚洲九九爱视频| 久久婷婷一区| 在线午夜精品自拍| 嫩模写真一区二区三区三州| 亚洲人成人77777线观看| 一区二区三区高清| 国产精品毛片va一区二区三区| 老司机免费视频一区二区三区| 亚洲欧洲另类国产综合| 欧美在线免费| 国产欧美亚洲精品| 欧美高清在线播放| 久久精品免费观看| 亚洲精品美女久久7777777| 香蕉尹人综合在线观看| 欧美日韩一区二区免费在线观看 | 久久综合精品国产一区二区三区| 亚洲精品中文字幕在线| 麻豆91精品| 精品成人一区二区三区| 久久久久成人网| 欧美一区成人| 国产乱人伦精品一区二区| 午夜精品成人在线视频| 中文在线一区| 国产精品狼人久久影院观看方式| 制服丝袜激情欧洲亚洲| 亚洲精品免费在线播放| 欧美理论电影在线播放| 99国产精品久久久久久久久久 | 影音先锋久久| 国产综合久久久久影院| 久久精品国产欧美激情| 性xx色xx综合久久久xx| 国产欧美精品一区二区三区介绍 | 欧美日韩精品在线播放| 99国产精品| 亚洲午夜羞羞片| 国产亚洲精品久| 国产精品视频成人| 欧美一区二区三区在| 欧美一区二区三区久久精品| 黄色亚洲网站| 免费成人av在线看| 欧美久久综合| 久久精品国产视频| 麻豆av福利av久久av| 一本大道久久a久久精品综合| 日韩一级精品| 亚洲美女在线看| 国产精品高清网站| 蜜桃精品一区二区三区| 欧美精品自拍| 久久精品观看| 欧美日本韩国一区| 欧美成人午夜免费视在线看片| 欧美高清自拍一区| 亚洲人成久久| 国产精品成人在线观看| 久久国产日韩| 欧美成人午夜激情在线| 欧美一区二区三区四区在线观看地址 | 久久天堂成人| 亚洲一区二区av电影| 久久久久女教师免费一区| 宅男精品视频| 久久久久久夜| 亚洲欧美另类国产| 免费不卡欧美自拍视频| 欧美一级理论片| 欧美日韩精品免费| 农村妇女精品| 国产精品久久久久一区| 欧美国产亚洲精品久久久8v| 国产精品视频一| 亚洲精品国产精品国自产观看 | 在线观看福利一区| 一区二区三区导航| 91久久在线视频| 新片速递亚洲合集欧美合集| 正在播放亚洲| 欧美电影免费观看高清| 麻豆精品视频在线观看| 国产精品性做久久久久久| 亚洲人成在线影院| 91久久国产自产拍夜夜嗨| 欧美一级在线视频| 欧美一区二区三区久久精品| 欧美日韩在线不卡| 亚洲第一色在线| 激情小说亚洲一区| 久久av红桃一区二区小说| 午夜日韩激情| 国产精品成人午夜| 99成人免费视频| 亚洲天堂成人在线视频| 欧美精品一区二区三区在线播放| 亚洲国产日韩一区| av成人手机在线| 亚洲成人在线网站| 国语自产精品视频在线看8查询8| 欧美jjzz| 欧美高清视频在线| 久久久噜噜噜久久狠狠50岁| 在线一区免费观看| 91久久久久| 欧美欧美天天天天操| 一区二区国产日产| 午夜精品理论片| 亚洲在线免费| 国产精品国产三级国产专播品爱网| 亚洲激情影院| 夜夜嗨av一区二区三区| 欧美日韩一区二区三区| 这里只有精品丝袜| 性欧美大战久久久久久久免费观看| 国产欧美一区二区三区国产幕精品| 午夜精品久久久久久久久久久久久 | 欧美视频二区| 亚洲影院色在线观看免费| 亚洲欧美成人| 国产日韩欧美不卡在线| 久久国产婷婷国产香蕉| 另类激情亚洲| 亚洲美女网站| 欧美性猛交视频| 欧美在线观看你懂的| 蜜臀久久99精品久久久久久9 | 午夜视频一区在线观看| 国内精品美女av在线播放| 久久综合成人精品亚洲另类欧美| 亚洲国产精品久久精品怡红院| 亚洲视频狠狠| 黄色日韩在线| 欧美色精品天天在线观看视频 | 亚洲精品国产精品乱码不99| 欧美一站二站| 亚洲区第一页| 国产精品久久久久久久久久免费看 | 久久综合中文| 在线亚洲+欧美+日本专区| 两个人的视频www国产精品| 一本色道久久综合亚洲91| 午夜精品免费在线| 老司机免费视频一区二区三区| 一区二区三区 在线观看视| 美女精品国产| 亚洲国产美国国产综合一区二区| 欧美一区午夜视频在线观看| 一本久道综合久久精品| 欧美日韩国产123| 99精品国产在热久久下载| 欧美日韩在线第一页| 在线精品视频在线观看高清| 欧美一区二区三区在线播放| 欧美国产亚洲另类动漫| 香蕉久久夜色| 一区二区国产在线观看| 亚洲国产天堂久久综合| 国产欧美综合在线| 欧美午夜www高清视频| 欧美激情第9页| 久久综合色婷婷| 久久一区欧美| 久久精彩免费视频| 欧美在线观看一区|