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

Rss & SiteMap

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

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

標題:Oracle 數(shù)據(jù)庫常用方法封裝類

1樓
wangxinxin 發(fā)表于:2010-12-11 10:53:01
#include <TChar.h>
#include <stdio.h>
#include <stdlib.h>

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

// 配置數(shù)據(jù)源必須頭文件
#include <odbcinst.h>
/*---------------------------------------------------------------------------*/
/*-------------------------- OracleDataBaseCtrl.h ---------------------------*/
/*---------------------------------------------------------------------------*/
/*
模塊名稱:OracleDataBaseCtrl.dll
版    本:0.1 Alpha
版    權(quán):
模塊功能:Oracle 數(shù)據(jù)庫操作類
作    者:wlzqi
作者郵箱:mailto:wlzqin@sina.com
建立時間:2006年7月3日
最后修改:by wlzqi 2006年7月4日
修改歷程:
注意事項:1.支持 UNICODE、ANSI 編碼
    2.當使用 get_collect_value 方法時,如果返回值是 NULL 則會發(fā)生異常,請注意處理。
備  注: 測試環(huán)境 WinXp + Vc 2003
使用舉例:
  ★// 定義對象
  COracleDataBaseCtrl m_OracleDataBase;
  ★// 1.打開數(shù)據(jù)庫
  m_OracleDataBase.open_database(數(shù)據(jù)庫MDB文件路徑, 用戶名, 密碼);   // 如沒有用戶名和密碼可以不寫
  ★// 2.關(guān)閉數(shù)據(jù)庫
  m_OracleDataBase.close_database();
  ★// 3.打開數(shù)據(jù)庫表
  // m_OracleDataBase.open_table(表名);
  ★// 4.刪除表
  m_OracleDataBase.del_table(表名);
  ★// 5.關(guān)閉數(shù)據(jù)庫表
  m_OracleDataBase.close_table();
  ★// 6.遍歷數(shù)據(jù)庫表
  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.獲取字段數(shù)量
  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.執(zhí)行 SQL 語句
  m_OracleDataBase.execute_sql(SQL 語句);
  ★// 13.獲取數(shù)據(jù)庫內(nèi)容
  m_OracleDataBase.execute_sql(_TEXT(\\\"SELECT * FROM 表名\\\"));  // 查詢所有數(shù)據(jù)
  m_OracleDataBase.execute_sql(_TEXT(\\\"SELECT COUNT(*) FROM 表名\\\"));  // 得到數(shù)據(jù)庫記錄條數(shù)
  _variant_t vtItemCount = m_OracleDataBase.get_collect_value(long(0));
  _bstr_t bsValue = vtItemCount;  // 將結(jié)果格式化為字符串
  ★// 14.遍歷數(shù)據(jù)庫所有內(nèi)容
  TCHAR szSQL[MAX_PATH];
  _stprintf(szSQL, _TEXT(\\\"SELECT * FROM %s\\\"), ptTableName);  // 格式化 SQL 語句
  m_OracleDataBase.execute_sql(szSQL);   // 執(zhí)行 SQL 語句
  m_OracleDataBase.first();  // 將游標移動到第一條數(shù)據(jù)
  _bstr_t bsValue;
  for (int i = 0; i < vtItemCount.intVal; i++) {    // 循環(huán)所用行
   if (m_OracleDataBase.Is_BOF() == 1) break;   // 如到了表最后則退出循環(huán)
   for (int j = 0; j < nFieldCount; j++) {   // 循環(huán)所有列
    variant_t vtValue = m_OracleDataBase.get_collect_value(long(j));  // 格式化得到的每列數(shù)據(jù)為字符串
    bsValue = _bstr_t(vtValue.vt == VT_NULL ? _TEXT(\\\"\\\") : vtValue.vt);
   }
   bfOk = m_AccessDataBaseCtrl.next();   // 移動到下一列
  }
  ★// 15.刪除當前行
  m_OracleDataBase.del_collect_value();
  ★// 16.注冊數(shù)據(jù)庫
  COracleDataBaseCtrl::Configuration_DataBaseSource(DNS, 數(shù)據(jù)庫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:
 // 打開數(shù)據(jù)庫
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT open_database(PCTSTR pctsUser, PCTSTR pctsPass, PCTSTR pctsServer, long Options = adModeUnknown);
 // 斷開數(shù)據(jù)庫
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT close_database();
 //****************************************************************************
 // 打開表
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT open_table(PCTSTR pctsTableName, long Options = adCmdText);
 // 關(guān)閉表
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT close_table();
 // 創(chuàng)建表創(chuàng)建表和字段
 // 用 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);
 // 得到表的字段數(shù)量
 unsigned long get_field_count(PCTSTR pctsTableName);
 // 得到表的字段名
 PCTSTR get_field_name(unsigned long unFieldIndex, PCTSTR pctsTableName);
 // 得到字段的類型
 // 參數(shù):pFieldType [OUT] 字段類型
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT get_field_type(unsigned long unFieldIndex, DataTypeEnum &FieldType);
 // 遍歷所有表名(第一個)
 // 參數(shù):ptTableName [OUT]  遍歷到的表名
 // 注意:if (lstrcmp(ptTableName, _TEXT(\\\"\\\")) != 0 ) 表名才有效
 // 返回:false 出錯或遍歷完畢
 bool first_table_name(PTSTR &ptsTableName);
 // 遍歷所有表名(下一個)
 // 參數(shù):ptTableName [OUT]  遍歷到的表名
 // 注意:if (lstrcmp(ptTableName, _TEXT(\\\"\\\")) != 0 ) 表名才有效
 // 返回:false 出錯或遍歷完畢
 bool next_table_name(PTSTR &ptsTableName);
 //****************************************************************************
 // 執(zhí)行 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);
 // 獲取數(shù)據(jù)
 _variant_t get_collect_value(PCTSTR pctsCollectName);
 // 獲取數(shù)據(jù)
 _variant_t get_collect_value(long lCollectIndex);
 // 設(shè)置數(shù)據(jù)
 bool put_collect_value(PCTSTR pctsCollectName, _variant_t vtValue);
 // 設(shè)置數(shù)據(jù)
 bool put_collect_value(long lCollectIndex, _variant_t vtValue);
 // 刪除一行數(shù)據(jù)(當前)
 bool del_collect_value();
 //****************************************************************************
 // 配置數(shù)據(jù)源
 static bool Configuration_DataBaseSource(PCTSTR pctDNS, PCTSTR pctDBPath, PCTSTR pctDescription);
};
/*---------------------------------------------------------------------------*/
/*-----------------------End OracleDataBaseCtrl.h ---------------------------*/
/*---------------------------------------------------------------------------*/
 
 
/*---------------------------------------------------------------------------*/
/*------------------------ OracleDataBaseCtrl.cpp ---------------------------*/
/*---------------------------------------------------------------------------*/
// OracleDataBaseCtrl.cpp : 定義 DLL 應(yīng)用程序的入口點。
//
#include \\\"stdafx.h\\\"
#include \\\"OracleDataBaseCtrl.h\\\"

//****************************************************************************
// 數(shù)據(jù)庫表名
TCHAR * pszTableName;
// 數(shù)據(jù)庫字段名
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 .04688 s, 2 queries.
毛片网站在线看_天堂俺去俺来也www久久婷婷_日韩av免费网站_18性欧美xxxⅹ性满足_一区二区三区韩国免费中文网站 _性xx色xx综合久久久xx_999亚洲国产精
国产午夜精品一区二区三区四区 | 国产精品99久久久| 奇米一区二区三区| 亚洲国产一区二区三区| 一区二区免费看| 免费的成人av| 久久国产精品72免费观看| 日韩电影一区二区三区四区| 天天射综合影视| 日日夜夜免费精品| 成人精品视频一区二区三区| 亚洲欧洲综合另类| 国产网红主播福利一区二区| 精品久久久三级丝袜| 91麻豆精品国产91久久久久久| 3d成人动漫网站| 欧美日韩一级二级| 国产在线国偷精品免费看| 国产一区二区网址| 色噜噜久久综合| 欧美日韩国产一二三| 高清国产一区二区三区| 国产激情视频一区二区在线观看| 美国十次综合导航| 波多野结衣欧美| 亚洲狠狠丁香婷婷综合久久久| 色综合久久中文字幕| 91美女在线视频| 亚洲女子a中天字幕| 成人高清视频在线观看| 亚洲一区影音先锋| 91精品黄色片免费大全| 丁香桃色午夜亚洲一区二区三区| 亚洲图片激情小说| 2020国产精品自拍| 在线观看日产精品| 亚洲另类色综合网站| 国产美女精品人人做人人爽 | 久久久亚洲欧洲日产国码αv| 国产乱理伦片在线观看夜一区 | 国产米奇在线777精品观看| 欧美精品久久一区二区三区| 亚洲色图19p| 欧洲人成人精品| 国产精品88av| 国产福利一区二区三区视频在线| 在线免费亚洲电影| fc2成人免费人成在线观看播放 | 日韩美女视频一区二区| 国产一区二区三区电影在线观看| 久久综合网色—综合色88| 国产成人啪免费观看软件 | 欧美日韩在线精品一区二区三区激情 | 精品黑人一区二区三区久久| 中文字幕第一区| 91国产丝袜在线播放| 亚洲国产成人av网| 1000精品久久久久久久久| 国产精品午夜春色av| 精品久久久久久久久久久久久久久| 色偷偷久久人人79超碰人人澡| 午夜伦理一区二区| 国内外成人在线视频| 日本视频在线一区| 国产传媒一区在线| 美女网站一区二区| 一区二区三区欧美在线观看| 欧美视频你懂的| 在线观看成人小视频| 99精品一区二区三区| 成人免费黄色在线| 欧美性受xxxx| 日韩三级高清在线| 亚洲三级免费电影| 91伊人久久大香线蕉| 久久夜色精品一区| 中文字幕日韩一区二区| 午夜伊人狠狠久久| 国产精品私人影院| 亚洲女女做受ⅹxx高潮| 91网址在线看| 国产欧美日韩综合精品一区二区| 精品成人免费观看| 日韩国产欧美一区二区三区| 91麻豆精品久久久久蜜臀| 免费人成网站在线观看欧美高清| 麻豆91精品视频| 国产成人精品在线看| 欧美军同video69gay| 在线亚洲一区观看| 欧美三级电影网| 制服丝袜av成人在线看| 亚洲小说欧美激情另类| 粉嫩欧美一区二区三区高清影视 | 欧美aaa在线| 亚洲国产精品一区二区www在线| 一本大道综合伊人精品热热| 亚洲天堂2014| 91国偷自产一区二区使用方法| 日本特黄久久久高潮| 欧美mv日韩mv国产网站| 色综合天天狠狠| 欧美经典一区二区| 欧洲视频一区二区| 三级亚洲高清视频| 在线视频你懂得一区| 亚洲人成网站色在线观看| 国产精品资源站在线| 免费精品视频在线| 国产激情一区二区三区四区 | 丝袜诱惑制服诱惑色一区在线观看 | 六月婷婷色综合| 91精品欧美福利在线观看| 亚洲图片欧美激情| 91婷婷韩国欧美一区二区| 亚洲国产成人私人影院tom | 成人久久18免费网站麻豆 | 色综合久久精品| 欧美96一区二区免费视频| 亚洲特级片在线| 8x8x8国产精品| 成a人片国产精品| 天天做天天摸天天爽国产一区| 国产精品你懂的| 国内精品在线播放| 国产精品456露脸| 激情伊人五月天久久综合| 国产精品久久久久久久久久久免费看 | 日本aⅴ亚洲精品中文乱码| 国产精品久久三| 在线成人高清不卡| 色欧美片视频在线观看| 国产91精品露脸国语对白| 视频在线观看国产精品| 国产精品久久久久久久裸模| 久久九九久精品国产免费直播| 91精品国产欧美一区二区| 在线精品视频一区二区三四| 亚洲电影中文字幕在线观看| 亚洲男同性恋视频| 亚洲三级在线播放| 天天综合网 天天综合色| 日韩欧美国产一二三区| 91国偷自产一区二区三区成为亚洲经典| 免费观看日韩av| 国产精品三级在线观看| 日韩亚洲电影在线| 99久久久久免费精品国产| 国产精品白丝jk黑袜喷水| 国产丝袜美腿一区二区三区| 欧美一区三区四区| 精品国产乱码久久久久久夜甘婷婷| 欧美本精品男人aⅴ天堂| 欧美嫩在线观看| 成人免费看黄yyy456| 国产一区在线看| 视频在线在亚洲| 日韩在线观看一区二区| 精品亚洲成a人在线观看| 麻豆国产欧美日韩综合精品二区| 不卡的av在线| 日韩欧美国产小视频| 亚洲免费看黄网站| 午夜激情久久久| 激情综合网av| 韩国精品主播一区二区在线观看| 久久精品国产亚洲5555| 亚洲色图20p| 亚洲激情第一区| 国产伦精一区二区三区| 国产精品乱子久久久久| 欧美精品xxxxbbbb| 久久你懂得1024| 亚洲欧美日韩一区二区 | 欧美日韩黄色影视| 午夜视频在线观看一区| 亚洲欧美电影一区二区| 日韩一区二区免费高清| 成人avav在线| 欧美大片免费久久精品三p| 午夜精品久久久久久久久久久| 一道本成人在线| 成人av中文字幕| 免费成人在线播放| 欧美日韩二区三区| 中文字幕一区二区三区蜜月| 久久免费美女视频| 美女在线观看视频一区二区| 欧美久久一区二区| 亚洲成人精品一区二区| 99re成人精品视频| 亚洲精品五月天| 免费在线观看视频一区| 日韩视频免费观看高清完整版在线观看| 日韩不卡免费视频| 精品美女一区二区| 国产高清视频一区| 中文字幕不卡在线| 91浏览器打开| 香港成人在线视频|