久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区

Rss & SiteMap

曙海教育集團論壇 http://www.bjzhda.cn

曙海教育集團論壇
共1 條記錄, 每頁顯示 10 條, 頁簽: [1]
[瀏覽完整版]

標題:Oracle 數據庫常用方法封裝類

1樓
wangxinxin 發表于:2010-12-11 10:53:01
#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);
}
共1 條記錄, 每頁顯示 10 條, 頁簽: [1]

Copyright © 2000 - 2009 曙海教育集團
Powered By 曙海教育集團 Version 2.2
Processed in .01563 s, 2 queries.
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
91片黄在线观看| 日韩毛片精品高清免费| 亚洲福利视频导航| 女人一区二区三区| 亚洲精品一卡二卡| 日韩久久久久久久| 亚洲图片欧美色图| 一区二区三区欧美成人| 蜜臀久久久久久久| 欧美日韩国产三级| 福利一区福利二区| 久久亚洲一区二区三区明星换脸| 不卡的电影网站| 久久久久国色av免费看影院| 粉嫩精品一区二区三区在线观看| 国产精品嫩草影院com| 久久青青草综合| 亚洲国产另类av| 日本精品免费观看高清观看| 久久99最新地址| 欧美一区午夜视频在线观看| 97精品国产露脸对白| 成人黄色av网站在线| 精品理论电影在线观看| 粉嫩av四季av绯色av第一区| 亚洲伦理在线免费看| 色综合天天综合| 国产河南妇女毛片精品久久久 | 国产综合色产在线精品| 日韩一卡二卡三卡| av激情久久| 亚洲午夜三级在线| 欧美日韩一区 二区 三区 久久精品 | 日韩激情久久| 麻豆国产精品777777在线| 日韩欧美国产一二三区| 国产a一区二区| 五月婷婷激情综合| 日韩一级片网站| 精品国产乱码久久久久久88av| 午夜精品视频在线观看| 3d动漫精品啪啪1区2区免费| 成人欧美一区二区三区黑人免费| 亚洲一区二区三区影院| 在线播放国产精品二区一二区四区 | 欧美一级久久久| 激情小说综合区| 麻豆91在线播放免费| 久久综合色之久久综合| 欧美综合77777色婷婷| 久久不见久久见中文字幕免费| 久久精品水蜜桃av综合天堂| 亚洲精品一卡二卡三卡四卡| 成人免费观看男女羞羞视频| 亚洲综合网站在线观看| 日韩一本二本av| 热re99久久精品国99热蜜月| 国产原创一区二区三区| 综合精品久久久| 欧美日韩国产欧美日美国产精品| 国产aⅴ精品一区二区三区黄| 免费观看久久久4p| 国产精品午夜春色av| 在线观看成人免费视频| 国产成人精品福利一区二区三区| 日韩av成人高清| 亚洲国产高清在线观看视频| 欧美亚洲国产一区二区三区va| 国产乱人伦精品一区二区| 久久99国产精品久久99果冻传媒| 最新不卡av在线| 欧美岛国在线观看| 一本一道久久a久久精品综合蜜臀| 91在线播放网址| 久久国产尿小便嘘嘘| 亚洲免费伊人电影| 精品国产免费人成在线观看| 色菇凉天天综合网| 久久一区二区三区欧美亚洲| 波多野结衣亚洲| 日本在线观看不卡视频| 中文字幕一区日韩精品欧美| 日韩欧美一区二区不卡| 色婷婷综合在线| 美女被啪啪一区二区| 99久久综合狠狠综合久久| 久久99精品国产.久久久久久| 亚洲欧美一区二区不卡| wwwwxxxxx欧美| 欧美日韩精品免费| 在线国产精品网| 欧美日韩在线精品| 成人免费在线看片| av电影在线观看完整版一区二区| 久草在线在线精品观看| 午夜精品福利一区二区蜜股av| 中文字幕一区av| 久久久91精品国产一区二区三区| 91精品国产色综合久久| 欧美吞精做爰啪啪高潮| 亚洲va久久久噜噜噜久久狠狠| 国产日韩三区| 999视频在线观看| av电影在线观看不卡| 国产成人免费9x9x人网站视频| 理论电影国产精品| 婷婷综合五月天| 亚洲国产精品一区二区久久恐怖片| 欧美国产日韩a欧美在线观看| 2020国产精品自拍| 日韩美女视频一区二区在线观看| 欧美日韩一区精品| 欧美视频一区二| 欧美视频中文字幕| 欧美优质美女网站| 日本韩国一区二区三区视频| 中文字幕av日韩精品| 亚洲国产欧美日韩| 手机看片福利永久国产日韩| 欧美一区亚洲二区| 秋霞毛片久久久久久久久| 欧美美乳视频网站在线观看| 国产精品视频入口| 国产精品一级久久久| 国产富婆一区二区三区| 国产精品12| 久久国产精品一区二区三区四区| 国产精品伊人日日| 久久国产精品一区二区三区四区| 久久另类ts人妖一区二区| 蜜桃av久久久亚洲精品| 欧美系列一区| 亚洲高清在线播放| 色哟哟精品一区| 在线免费精品视频| 欧美精品久久99| 日韩免费高清视频| 久久久91精品国产一区二区三区| 国产亚洲一区二区三区在线观看 | 欧美一区二区三区四区夜夜大片 | 韩国女主播成人在线观看| 狠狠色狠狠色综合系列| 国产成人一级电影| 99精品国产视频| 国产一区二区三区免费不卡| 久久精品国产一区二区三区日韩 | 91在线免费看| 福利视频久久| 日韩欧美亚洲日产国| 色综合久久综合网| 欧美日韩高清在线播放| 日韩欧美www| 国产日韩欧美精品综合| 亚洲免费av网站| 五月激情综合婷婷| 国产精品996| 国产精品12| 一区二区三区四区不卡| 欧美美女一区二区在线观看| 久久综合色综合88| 一区二区三区欧美日| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品77777| 国产一级二级三级精品| 亚洲一区二区在线观| 欧美肥胖老妇做爰| 亚洲国产精品精华液ab| 亚洲国产乱码最新视频| 国内精品免费在线观看| 国产99在线播放| 色婷婷国产精品综合在线观看| 91精品国产综合久久国产大片| 中文一区在线播放| 日韩高清电影一区| www.欧美.com| 日韩三级电影免费观看| 欧美一区二区三区在| 中文字幕中文字幕在线一区 | 久久久亚洲精品石原莉奈| 亚洲人成网站色在线观看| 麻豆91小视频| 国产日韩二区| 欧美无乱码久久久免费午夜一区 | 日本一区二区精品| 欧美精品自拍偷拍动漫精品| 中文字幕精品一区二区精品绿巨人 | 色综合久久中文字幕| 精品久久国产字幕高潮| 亚洲综合精品久久| 成人黄色免费短视频| 日韩美女一区| 久久这里只有精品6| 亚洲电影激情视频网站| 91在线视频观看| 91久久精品日日躁夜夜躁欧美| 久久久蜜桃精品| 麻豆成人免费电影| 精品国产一区二区三| 69久久夜色精品国产69蝌蚪网| 亚洲精品自拍动漫在线|