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

Khan's Notebook GCC/GNU/Linux Delphi/Window Java/Anywhere

路漫漫,長修遠,我們不能沒有錢
隨筆 - 173, 文章 - 0, 評論 - 257, 引用 - 0
數據加載中……

[導入]libsdb字段名的解決方案。自己分析sql語句中的select 字段名,自己維護

這個不是一個很好的解決方案,浪費了很多內存空間,我覺得比較好的,方案應該是2個vector 
一個用來存放一條記錄或字段名,另一個存放這個vector
/**dbm.hpp
 * 數據庫操作的模塊,本系統中所有的數據庫操作都集成于本模塊
 * */

#include
<string>
#include <map>
#include
<vector>
#include "common.h"
#include "sdb.h"

using namespace std;
typedef map<string, string> TRecord;
 typedef vector<string> Tcols;
 typedef vector<TRecord> TDataSet;
 typedef TRecord::iterator TDataSetIter;
 typedef TRecord::value_type TValueType;

 /* 本類不會主動關閉數據庫連接*/
class TDB_Action{
  private:
 char* db; //數據庫連接
  TDataSet dataset; //結果集
TDataSet *pd; //指向結果集的指針
static Tcols record_cols; //字段元素

/*回調函數
 *@param int n 字段個數
 *@param char **p 結果集
 *@param void * data 數據的出口
 */
 static int DB_record_callback(int n, char **p, void *data){
  if (!n) return 0;
  TRecord record;
  record.clear();
  for(int i = 0; i < n; i++){
 record.insert(TValueType( record_cols[i], p[i]));
  //printf("%s %s \t" , record_cols[i].c_str() ,p[i]);//
 } //printf("\n" );//
 ((TDataSet *)data)->push_back(record);
  }

 public:
 /*構造器*/
 TDB_Action(char* the_db){
 db=the_db;
 pd=&dataset;
 }

 /*析構器*/
  ~TDB_Action(){};

  /* 執行無結果集的sql語句
 * @param char *sqlstr sql語句
*/

 int DB_Excute( char *sqlstr);

  /*執行有結果集的sql語句
 * @param Tcols 一個vector,存儲多個字段
 * @param string table_name 表名
  * @param const condstion where條件
 * @return TDataSet 一個結果集*/

 TDataSet DB_GetRecord(Tcols the_cols, string table_name, const string condtion);

 };


/*dbm.cpp*/
#include "dbm.hpp"

 Tcols TDB_Action::record_cols; //類靜態成員變量需要在cpp中再申明一次,剛剛才知道d
 /*
 * */
 int TDB_Action::DB_Excute( char *sqlstr) {
 if (-1 == sdb_query(db, sqlstr, NULL, NULL)) {
 fprintf(stderr, "Error in Execute sql statement <%s>\n", sqlstr);
  return -1;
}
 return 1;
 }

 TDataSet TDB_Action::DB_GetRecord(Tcols the_cols, string table_name, const string condtion){
 for(int i=0; i<dataset.size(); i++){
 dataset[i].clear();
 }
 dataset.clear();
 record_cols.clear();
 if (the_cols.size()<=0)
 return dataset;//如果沒有字段,直接返回
 char sqlstr[400] ;
 memset(sqlstr, '0', sizeof(sqlstr));
 string tmp(""); //構建一個sql語句

 for (int i =0; i < the_cols.size() ; i++ ){
 record_cols.push_back( the_cols[i].c_str());
 if( the_cols[i] == "*" )
 return dataset; //不能包含*

 if( i < the_cols.size() -1)
 tmp = tmp + the_cols[i] + ", ";
 else
 tmp = tmp + the_cols[i] ;
 }

  tmp = "Select " + tmp + " From " + table_name + condtion;
 sprintf(sqlstr, tmp.c_str());
 if (-1 == sdb_query(db, sqlstr, DB_record_callback, pd)) {
 fprintf(stderr, "Error in Query sql statement <%s>\n", sqlstr);
 return dataset;
 }
 return dataset;
 }

 int main(){//測試代碼
 char *db = NULL;
 char url[1024]="mysql:host=127.0.0.1:db=smscgw:uid=root";
 db=sdb_open(url);
 if (db == NULL) {
 fprintf(stderr, "Open database fault <%s>\n", url);
 exit (-1);
 }

 TDB_Action dba(db);
 Tcols te; string strs[5] = {"acttime","seq_num","msg","connname","mtmsg"};

 te.push_back(strs[0]);
 te.push_back(strs[1]);
 te.push_back(strs[2]);
 te.push_back(strs[3]);
 const string aaa(" ORDER BY acttime ");


 //取結果集
 TDataSet temp= dba.DB_GetRecord(te, strs[4],aaa);
 printf("打印結果集\n");
 for(int i=0 ; i < temp.size(); i++){
 for(TDataSetIter it=temp[i].begin();it != temp[i].end(); it++){
  printf("key:%s :%s \t", it->first.c_str(), it->second.c_str());
 }
 printf("\n");
 }
  if ( db!= NULL)
 sdb_close(db);
 return 0;
 }

posted on 2006-01-12 09:56 Khan 閱讀(555) 評論(1)  編輯 收藏 引用 所屬分類: GCC/G++

評論

# re: [導入]libsdb字段名的解決方案。自己分析sql語句中的select 字段名,自己維護  回復  更多評論   

vim的代碼著色真是一流,呵呵
windows 下面也有GVim ,還可以生成 HTML
2006-01-27 13:45 | 思春貼調查員(Khan)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美另类在线| 亚洲国产成人久久| 久久久之久亚州精品露出| 亚洲欧美另类久久久精品2019| 日韩一级片网址| 一本色道久久综合亚洲91| 亚洲精品久久在线| 一本色道88久久加勒比精品 | 欧美一区免费| 久久久久国产精品麻豆ai换脸| 久久精品国产久精国产爱| 久久综合电影| 欧美日韩中文字幕在线| 国产欧美日韩视频一区二区| 国内精品久久久久久影视8| 欧美成人免费大片| 亚洲精品网站在线播放gif| 亚洲国产清纯| 亚洲午夜免费视频| 久久精品国产99| 欧美精品一区在线| 国产女主播一区| 亚洲国产色一区| 香蕉免费一区二区三区在线观看 | 亚洲一区在线观看视频| 欧美在线观看网址综合| 欧美欧美在线| 红桃视频亚洲| 亚洲欧美精品在线观看| 男女精品网站| 欧美亚洲网站| 国产精品二区三区四区| 亚洲人成毛片在线播放女女| 欧美一区二区三区精品电影| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美亚洲综合网| 国产精品久久久久毛片软件| 亚洲人成高清| 免费久久99精品国产自在现线| 亚洲午夜在线| 欧美日韩在线视频一区二区| 亚洲国产另类久久精品| 久久精品视频va| 亚洲欧美日韩在线综合| 欧美午夜性色大片在线观看| 亚洲精品资源美女情侣酒店| 久久综合给合久久狠狠狠97色69| 亚洲一区二区三区乱码aⅴ| 欧美激情亚洲自拍| 亚洲日韩欧美视频一区| 免费观看成人| 久久九九久精品国产免费直播| 国产精品免费福利| 午夜精品久久久久久久99热浪潮| 日韩一二三在线视频播| 欧美国产在线观看| 亚洲精品乱码久久久久久蜜桃麻豆| 久热成人在线视频| 欧美一区二区三区四区在线| 国产九九精品视频| 欧美一区成人| 午夜亚洲一区| 国内一区二区三区| 久久免费视频这里只有精品| 欧美一区成人| 国产一区二区按摩在线观看| 欧美在线二区| 久久国产66| 亚洲电影网站| 亚洲激情另类| 欧美婷婷六月丁香综合色| 欧美日韩亚洲不卡| 亚洲尤物视频网| 91久久精品一区二区别| 欧美99在线视频观看| 亚洲精品久久7777| 亚洲日本乱码在线观看| 欧美网站在线观看| 久久久免费av| 亚洲国产另类精品专区| 欧美成人久久| 久久综合网hezyo| 在线欧美日韩国产| 亚洲成人中文| 欧美日韩一区自拍| 小嫩嫩精品导航| 久久精品最新地址| 一本综合精品| 欧美呦呦网站| 日韩亚洲视频| 香蕉视频成人在线观看| 亚洲激情社区| 亚洲影音一区| 亚洲日韩中文字幕在线播放| 一本到高清视频免费精品| 国产亚洲精品一区二区| 久久久在线视频| 欧美va天堂| 亚洲一区二区三区在线| 久久久精品欧美丰满| 一区二区三区三区在线| 欧美在线黄色| 亚洲性xxxx| 欧美**人妖| 久久精品女人| 欧美日韩一区不卡| 久久综合亚洲社区| 欧美日韩中文字幕综合视频 | 亚洲美女av在线播放| 狠狠色综合网| 亚洲视频在线播放| 亚洲国产女人aaa毛片在线| 亚洲一区国产| 亚洲图片欧美午夜| 麻豆av一区二区三区久久| 欧美专区日韩视频| 欧美日韩中文字幕在线| 亚洲国内在线| 亚洲黑丝在线| 久久久精品五月天| 欧美在线亚洲在线| 欧美性事在线| 亚洲精品免费看| 亚洲国内精品| 免费成人黄色| 欧美成人免费播放| 狠狠入ady亚洲精品| 午夜精品理论片| 亚洲欧美自拍偷拍| 欧美调教vk| 一区二区日韩免费看| 一二三四社区欧美黄| 欧美日本国产一区| 91久久嫩草影院一区二区| 亚洲国产专区校园欧美| 亚洲高清资源| 在线观看成人一级片| 久久人人97超碰国产公开结果 | 亚洲国产精品成人综合色在线婷婷| 亚洲免费在线看| 亚洲欧美中文另类| 国产拍揄自揄精品视频麻豆| 午夜精彩国产免费不卡不顿大片| 性欧美精品高清| 国产女人精品视频| 欧美一区二区大片| 久久午夜影视| 亚洲国产高清在线| 欧美不卡在线视频| 亚洲激情一区二区三区| 一本色道久久88精品综合| 欧美日韩亚洲国产精品| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美精选在线| 中日韩视频在线观看| 性18欧美另类| 国精品一区二区| 麻豆精品在线播放| 亚洲每日在线| 久久精品视频免费播放| 一区二区三区亚洲| 欧美成人免费全部观看天天性色| 亚洲三级影片| 亚洲欧美综合精品久久成人 | 国产精品国产福利国产秒拍| 亚洲欧美国产制服动漫| 蜜臀av国产精品久久久久| 99re热精品| 国产日产欧产精品推荐色 | 国产精品入口尤物| 久久精品国产亚洲精品 | 亚洲午夜一级| 久久一区视频| 亚洲一区二区三区四区在线观看| 国产欧美日韩视频一区二区| 免费观看在线综合色| 亚洲午夜小视频| 欧美激情视频给我| 欧美一乱一性一交一视频| 一区免费在线| 欧美三级视频在线播放| 久久久国产一区二区三区| 一区二区欧美日韩| 亚洲国产欧美国产综合一区| 国产精品久久久99| 鲁大师影院一区二区三区| 中文av字幕一区| 久久婷婷国产综合国色天香| 一区二区三区不卡视频在线观看 | 国产欧美日韩伦理| 久久精彩免费视频| 99精品福利视频| 欧美成人自拍| 久久国产综合精品| 亚洲一区不卡| 亚洲精品视频二区| 伊大人香蕉综合8在线视| 国产精品丝袜久久久久久app| 欧美黄在线观看| 蜜臀99久久精品久久久久久软件|