毛片网站在线看_天堂俺去俺来也www久久婷婷_日韩av免费网站_18性欧美xxxⅹ性满足_一区二区三区韩国免费中文网站 _性xx色xx综合久久久xx_999亚洲国产精

以文本方式查看主題

-  曙海教育集團論壇  (http://www.scb-ycwb.com/bbs/index.asp)
--  Oracle數據庫  (http://www.scb-ycwb.com/bbs/list.asp?boardid=65)
----  Oracle 數據庫常用方法封裝類  (http://www.scb-ycwb.com/bbs/dispbbs.asp?boardid=65&id=2497)

--  作者:wangxinxin
--  發布時間:2010-12-11 10:53:01
--  Oracle 數據庫常用方法封裝類
#include <TChar.h>
#include <stdio.h>
#include <stdlib.h>

#pragma warning (disable:4251)
#pragma warning (disable:4313)

// 配置數據源必須頭文件
#include <odbcinst.h>
/*---------------------------------------------------------------------------*/
/*-------------------------- OracleDataBaseCtrl.h ---------------------------*/
/*---------------------------------------------------------------------------*/
/*
模塊名稱:OracleDataBaseCtrl.dll
版    本:0.1 Alpha
版    權:
模塊功能:Oracle 數據庫操作類
作    者:wlzqi
作者郵箱:mailto:wlzqin@sina.com
建立時間:2006年7月3日
最后修改:by wlzqi 2006年7月4日
修改歷程:
注意事項:1.支持 UNICODE、ANSI 編碼
    2.當使用 get_collect_value 方法時,如果返回值是 NULL 則會發生異常,請注意處理。
備  注: 測試環境 WinXp + Vc 2003
使用舉例:
  ★// 定義對象
  COracleDataBaseCtrl m_OracleDataBase;
  ★// 1.打開數據庫
  m_OracleDataBase.open_database(數據庫MDB文件路徑, 用戶名, 密碼);   // 如沒有用戶名和密碼可以不寫
  ★// 2.關閉數據庫
  m_OracleDataBase.close_database();
  ★// 3.打開數據庫表
  // m_OracleDataBase.open_table(表名);
  ★// 4.刪除表
  m_OracleDataBase.del_table(表名);
  ★// 5.關閉數據庫表
  m_OracleDataBase.close_table();
  ★// 6.遍歷數據庫表
  PTSTR ptTableName;
  for (bool bfOk = m_OracleDataBase.first_table_name(ptTableName); bfOk; bfOk = m_OracleDataBase.next_table_name(ptTableName)) {
   if (lstrcmp(ptTableName, _TEXT(\\\\\\"\\\\\\")) == 0) continue;
   // 得到表名
   MessageBox(ptTableName);
  }
  ★// 7.添加字段
  m_OracleDataBase.add_field(表名, 字段);  // 字段形式 _TEXT(\\\\\\"Field1 INTEGER, Field2 INTEGER, ...\\\\\\")
  ★// 8.刪除字段
  m_OracleDataBase.del_field(表名, 字段名);
  ★// 9.獲取字段數量
  int nFieldCount = m_OracleDataBase.get_field_count(表名);
  ★// 10.遍歷字段
  for (int i = 0; i < nFieldCount; i++) {
   PCTSTR pctFieldName = m_OracleDataBase.get_field_name(i, 表名);
   MessageBox(pctFieldName);
  }
  ★// 11.獲取字段類型
  DataTypeEnum FieldType;
  m_OracleDataBase.get_field_type(字段號, FieldType);  // 字段號:字段的序號(從 0 開始)
  ★// 12.執行 SQL 語句
  m_OracleDataBase.execute_sql(SQL 語句);
  ★// 13.獲取數據庫內容
  m_OracleDataBase.execute_sql(_TEXT(\\\\\\"SELECT * FROM 表名\\\\\\"));  // 查詢所有數據
  m_OracleDataBase.execute_sql(_TEXT(\\\\\\"SELECT COUNT(*) FROM 表名\\\\\\"));  // 得到數據庫記錄條數
  _variant_t vtItemCount = m_OracleDataBase.get_collect_value(long(0));
  _bstr_t bsValue = vtItemCount;  // 將結果格式化為字符串
  ★// 14.遍歷數據庫所有內容
  TCHAR szSQL[MAX_PATH];
  _stprintf(szSQL, _TEXT(\\\\\\"SELECT * FROM %s\\\\\\"), ptTableName);  // 格式化 SQL 語句
  m_OracleDataBase.execute_sql(szSQL);   // 執行 SQL 語句
  m_OracleDataBase.first();  // 將游標移動到第一條數據
  _bstr_t bsValue;
  for (int i = 0; i < vtItemCount.intVal; i++) {    // 循環所用行
   if (m_OracleDataBase.Is_BOF() == 1) break;   // 如到了表最后則退出循環
   for (int j = 0; j < nFieldCount; j++) {   // 循環所有列
    variant_t vtValue = m_OracleDataBase.get_collect_value(long(j));  // 格式化得到的每列數據為字符串
    bsValue = _bstr_t(vtValue.vt == VT_NULL ? _TEXT(\\\\\\"\\\\\\") : vtValue.vt);
   }
   bfOk = m_AccessDataBaseCtrl.next();   // 移動到下一列
  }
  ★// 15.刪除當前行
  m_OracleDataBase.del_collect_value();
  ★// 16.注冊數據庫
  COracleDataBaseCtrl::Configuration_DataBaseSource(DNS, 數據庫DB文件路徑, 描述);
  ★// 17.其它還有一些請參:OracleDataBaseCtrl.h 文件
  ★// 18.反注冊 COM   CoUninitialize();
*/
#pragma once

#pragma warning(disable:4146)
#import \\\\\\"c:\\\\\\\\Program Files\\\\\\\\Common Files\\\\\\\\System\\\\\\\\ado\\\\\\\\Msado15.dll\\\\\\" \\\\\\\\
no_namespace \\\\\\\\
rename (_TEXT(\\\\\\"EOF\\\\\\"), _TEXT(\\\\\\"adoEOF\\\\\\"))
#pragma warning(default:4146 )
 
 
#ifdef ORACLEDATABASECTRL_EXPORTS
#define ORACLEDATABASECTRL_API __declspec(dllexport)
#else
#define ORACLEDATABASECTRL_API __declspec(dllimport)
#endif
 

// 此類是從 OracleDataBaseCtrl.dll 導出的
class ORACLEDATABASECTRL_API COracleDataBaseCtrl {
public:
 COracleDataBaseCtrl(void);
 // TODO: 在此添加您的方法。
 ~COracleDataBaseCtrl();
 //****************************************************************************
private:
 _ConnectionPtr m_pConnection;
 _RecordsetPtr m_pRecordset;
 HRESULT hr;
 //****************************************************************************
public:
 // 打開數據庫
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT open_database(PCTSTR pctsUser, PCTSTR pctsPass, PCTSTR pctsServer, long Options = adModeUnknown);
 // 斷開數據庫
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT close_database();
 //****************************************************************************
 // 打開表
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT open_table(PCTSTR pctsTableName, long Options = adCmdText);
 // 關閉表
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT close_table();
 // 創建表創建表和字段
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT create_table(PCTSTR pctsTableName, PCTSTR pctsField, long Options = adCmdText);
 // 刪除表
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT del_table(PCTSTR pctsTableName, long Options = adCmdText);
 // 添加字段
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT add_field(PCTSTR pctsTableName, PCTSTR pctsField, long Options = adCmdText);
 // 刪除字段
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT del_field(PCTSTR pctsTableName, PCTSTR pctsFieldName, long Options = adCmdText);
 // 得到表的字段數量
 unsigned long get_field_count(PCTSTR pctsTableName);
 // 得到表的字段名
 PCTSTR get_field_name(unsigned long unFieldIndex, PCTSTR pctsTableName);
 // 得到字段的類型
 // 參數:pFieldType [OUT] 字段類型
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT get_field_type(unsigned long unFieldIndex, DataTypeEnum &FieldType);
 // 遍歷所有表名(第一個)
 // 參數:ptTableName [OUT]  遍歷到的表名
 // 注意:if (lstrcmp(ptTableName, _TEXT(\\\\\\"\\\\\\")) != 0 ) 表名才有效
 // 返回:false 出錯或遍歷完畢
 bool first_table_name(PTSTR &ptsTableName);
 // 遍歷所有表名(下一個)
 // 參數:ptTableName [OUT]  遍歷到的表名
 // 注意:if (lstrcmp(ptTableName, _TEXT(\\\\\\"\\\\\\")) != 0 ) 表名才有效
 // 返回:false 出錯或遍歷完畢
 bool next_table_name(PTSTR &ptsTableName);
 //****************************************************************************
 // 執行 SQL 語句
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT execute_sql(PCTSTR pctsSQL, long Options = adCmdText);
 // 是否到記錄集末端(0--沒有,1--是 -1--錯誤)
 int Is_BOF(void);
 // 跳向前一個記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT prev(void);
 // 遍歷到第一個記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT first(void);
 // 遍歷到下個記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT next(void);
 // 遍歷到最后一個記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT last(void);
 // 更新(確認)記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT update(void);
 // 重新查詢
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT reQuery(long Options = 0);
 // 記錄集是否為空(0--沒有,1--是 -1--錯誤)
 int Is_Empty(void);
 // 獲取數據
 _variant_t get_collect_value(PCTSTR pctsCollectName);
 // 獲取數據
 _variant_t get_collect_value(long lCollectIndex);
 // 設置數據
 bool put_collect_value(PCTSTR pctsCollectName, _variant_t vtValue);
 // 設置數據
 bool put_collect_value(long lCollectIndex, _variant_t vtValue);
 // 刪除一行數據(當前)
 bool del_collect_value();
 //****************************************************************************
 // 配置數據源
 static bool Configuration_DataBaseSource(PCTSTR pctDNS, PCTSTR pctDBPath, PCTSTR pctDescription);
};
/*---------------------------------------------------------------------------*/
/*-----------------------End OracleDataBaseCtrl.h ---------------------------*/
/*---------------------------------------------------------------------------*/
 
 
/*---------------------------------------------------------------------------*/
/*------------------------ OracleDataBaseCtrl.cpp ---------------------------*/
/*---------------------------------------------------------------------------*/
// OracleDataBaseCtrl.cpp : 定義 DLL 應用程序的入口點。
//
#include \\\\\\"stdafx.h\\\\\\"
#include \\\\\\"OracleDataBaseCtrl.h\\\\\\"

//****************************************************************************
// 數據庫表名
TCHAR * pszTableName;
// 數據庫字段名
TCHAR * pszFieldName;
//****************************************************************************
COracleDataBaseCtrl::COracleDataBaseCtrl()
: m_pConnection(NULL)
, m_pRecordset(NULL)
, hr(NULL)
{
 // 初始化COM
 if(FAILED(::CoInitialize(NULL))) return;
 pszTableName = (TCHAR *)malloc(MAX_PATH);
 if (pszTableName == NULL) return;
 pszFieldName = (TCHAR *)malloc(MAX_PATH);
 if (pszFieldName == NULL) return;
}
COracleDataBaseCtrl::~COracleDataBaseCtrl()
{
 // 反注冊COM
 CoUninitialize();
 if (pszTableName != NULL) free(pszTableName);
 if (pszFieldName != NULL) free(pszFieldName);
}

毛片网站在线看_天堂俺去俺来也www久久婷婷_日韩av免费网站_18性欧美xxxⅹ性满足_一区二区三区韩国免费中文网站 _性xx色xx综合久久久xx_999亚洲国产精
污片在线观看一区二区| 国产精品久久久久久妇女6080| 国产精品一区二区男女羞羞无遮挡| 视频精品一区二区| 婷婷中文字幕综合| 日韩国产在线观看| 国产一区二区三区久久悠悠色av | 91一区二区三区在线观看| 色综合天天综合网国产成人综合天| 色综合天天综合网国产成人综合天 | 亚洲电影你懂得| 中文字幕在线免费不卡| 亚洲人成精品久久久久| 日韩精品乱码免费| 国产v日产∨综合v精品视频| 一本到三区不卡视频| 欧美精品久久天天躁| 久久嫩草精品久久久久| 国产精品久久久久一区二区三区 | 亚洲欧洲精品一区二区三区 | 在线观看亚洲a| 精品成人一区二区三区四区| 中文字幕一区二区三区色视频| 亚洲成年人影院| 成人一区二区三区在线观看| 欧美性生活大片视频| 欧美成人一区二区| 亚洲欧美视频一区| 韩国av一区二区三区在线观看| av一区二区三区四区| 日韩一区二区在线看| 1024成人网| 国产在线精品视频| 欧美日韩专区在线| 国产精品美女久久福利网站| 日韩福利电影在线| 色综合久久综合网97色综合| 精品国产自在久精品国产| 亚洲在线视频一区| 成人黄色免费短视频| 日韩欧美高清在线| 亚洲成人777| 91看片淫黄大片一级在线观看| 欧美成va人片在线观看| 午夜欧美大尺度福利影院在线看| 97久久人人超碰| 国产三级精品在线| 蜜臀久久99精品久久久久宅男| 在线一区二区三区四区| 中文字幕欧美激情| 久久91精品国产91久久小草| 91精品国产综合久久久久久久久久 | 亚洲欧美乱综合| 免费不卡在线视频| 在线观看免费视频综合| 成人欧美一区二区三区黑人麻豆| 国产一区二区女| 欧美mv日韩mv国产网站app| 视频一区视频二区中文字幕| 欧美三级日韩在线| 亚洲综合偷拍欧美一区色| www.亚洲国产| 中文字幕一区二区三| 成人在线视频一区二区| 欧美国产日韩亚洲一区| 国产成人一区在线| 国产欧美日韩在线| 成人性生交大片免费| 欧美极品xxx| 不卡一卡二卡三乱码免费网站| 中文字幕乱码一区二区免费| 国产成人综合亚洲网站| 中文字幕精品一区二区精品绿巨人| 精品系列免费在线观看| 久久亚洲精精品中文字幕早川悠里| 久久99热99| 久久久久久97三级| 大美女一区二区三区| |精品福利一区二区三区| 色香蕉成人二区免费| 亚洲综合激情另类小说区| 欧美性生活久久| 美腿丝袜在线亚洲一区| 2020国产成人综合网| 国产精品1024| 亚洲猫色日本管| 91精品在线一区二区| 国产一区二区三区香蕉| 国产精品久久久久一区二区三区共| 色婷婷激情久久| 日本欧美在线看| 国产午夜亚洲精品羞羞网站| 91丨九色porny丨蝌蚪| 亚洲成人免费视| 精品久久久久久最新网址| 国产麻豆精品久久一二三| 成人欧美一区二区三区在线播放| 欧美调教femdomvk| 精品一区二区三区久久| 国产精品无圣光一区二区| 欧美色图在线观看| 久久精品国产77777蜜臀| 国产精品嫩草久久久久| 欧美午夜影院一区| 福利视频网站一区二区三区| 亚洲精品va在线观看| 日韩一区二区电影| 91丝袜国产在线播放| 久久国产福利国产秒拍| 亚洲欧美aⅴ...| 精品sm捆绑视频| 91高清视频在线| 国产美女久久久久| 亚洲一区二区三区中文字幕| 国产亚洲成av人在线观看导航| 欧美三片在线视频观看| 国产v日产∨综合v精品视频| 日韩二区在线观看| 依依成人精品视频| 亚洲精品一区二区三区精华液| 在线欧美小视频| 东方aⅴ免费观看久久av| 全国精品久久少妇| 玉足女爽爽91| 久久久精品国产免大香伊| 欧美人xxxx| 91高清视频免费看| 成人黄色电影在线| 国产精一区二区三区| 日韩一区精品视频| 亚洲激情一二三区| 国产精品麻豆欧美日韩ww| 欧美大片一区二区| 这里只有精品电影| 欧美日韩一区二区三区在线| 色悠久久久久综合欧美99| 不卡高清视频专区| 成人黄色网址在线观看| 国产在线国偷精品产拍免费yy| 蜜臀av性久久久久蜜臀av麻豆| 一区二区三区免费看视频| 欧美国产亚洲另类动漫| 久久综合狠狠综合久久综合88| 欧美一区二区精品在线| 91精品国产欧美一区二区成人| 不卡的av电影在线观看| 国产99久久精品| 国产一区福利在线| 久久99国产精品久久| 久久se这里有精品| 久久精品国产亚洲一区二区三区| 日韩中文欧美在线| 日韩在线观看一区二区| 日韩制服丝袜av| 美日韩黄色大片| 精品在线亚洲视频| 精品中文av资源站在线观看| 久久99在线观看| 国产一区二区三区在线看麻豆| 韩国一区二区三区| 国产一区二区免费在线| 国产成人自拍高清视频在线免费播放| 国产精品一级二级三级| 国产.精品.日韩.另类.中文.在线.播放| 韩国三级中文字幕hd久久精品| 韩国三级在线一区| 高清不卡一二三区| 色域天天综合网| 正在播放一区二区| 精品成人一区二区| 国产精品久久久久永久免费观看| 亚洲色图20p| 午夜精品久久久久久久久久| 久久精品国产精品亚洲精品| 国产一区二区在线视频| gogogo免费视频观看亚洲一| 欧美性猛片aaaaaaa做受| 日韩一区二区视频在线观看| 久久久久久久精| 亚洲另类色综合网站| 亚洲成年人网站在线观看| 久久av资源网| 91在线小视频| 日韩一区二区三区四区| 国产精品麻豆99久久久久久| 亚洲va在线va天堂| 国产激情视频一区二区在线观看 | 理论电影国产精品| www.66久久| 777奇米四色成人影色区| 久久婷婷国产综合精品青草| 亚洲精选视频在线| 蜜臀av国产精品久久久久 | 色成年激情久久综合| 日韩丝袜情趣美女图片| 18成人在线观看| 国产在线精品免费av| 欧美性受xxxx黑人xyx| 国产亚洲精品aa| 日本女人一区二区三区|