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


曙海教育集團(tuán)論壇開發(fā)語(yǔ)言培訓(xùn)專區(qū)Oracle數(shù)據(jù)庫(kù) → Oracle 數(shù)據(jù)庫(kù)常用方法封裝類


  共有9445人關(guān)注過(guò)本帖樹形打印

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

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個(gè)性首頁(yè) | 博客 | 信息 | 搜索 | 郵箱 | 主頁(yè) | UC


加好友 發(fā)短信
等級(jí):青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊(cè):2010-11-12 11:08:23
Oracle 數(shù)據(jù)庫(kù)常用方法封裝類  發(fā)帖心情 Post By: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ù)庫(kù)操作類
作    者:wlzqi
作者郵箱:mailto:wlzqin@sina.com
建立時(shí)間:2006年7月3日
最后修改:by wlzqi 2006年7月4日
修改歷程:
注意事項(xiàng):1.支持 UNICODE、ANSI 編碼
    2.當(dāng)使用 get_collect_value 方法時(shí),如果返回值是 NULL 則會(huì)發(fā)生異常,請(qǐng)注意處理。
備  注: 測(cè)試環(huán)境 WinXp + Vc 2003
使用舉例:
  ★// 定義對(duì)象
  COracleDataBaseCtrl m_OracleDataBase;
  ★// 1.打開數(shù)據(jù)庫(kù)
  m_OracleDataBase.open_database(數(shù)據(jù)庫(kù)MDB文件路徑, 用戶名, 密碼);   // 如沒(méi)有用戶名和密碼可以不寫
  ★// 2.關(guān)閉數(shù)據(jù)庫(kù)
  m_OracleDataBase.close_database();
  ★// 3.打開數(shù)據(jù)庫(kù)表
  // m_OracleDataBase.open_table(表名);
  ★// 4.刪除表
  m_OracleDataBase.del_table(表名);
  ★// 5.關(guān)閉數(shù)據(jù)庫(kù)表
  m_OracleDataBase.close_table();
  ★// 6.遍歷數(shù)據(jù)庫(kù)表
  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(字段號(hào), FieldType);  // 字段號(hào):字段的序號(hào)(從 0 開始)
  ★// 12.執(zhí)行 SQL 語(yǔ)句
  m_OracleDataBase.execute_sql(SQL 語(yǔ)句);
  ★// 13.獲取數(shù)據(jù)庫(kù)內(nèi)容
  m_OracleDataBase.execute_sql(_TEXT(\\\"SELECT * FROM 表名\\\"));  // 查詢所有數(shù)據(jù)
  m_OracleDataBase.execute_sql(_TEXT(\\\"SELECT COUNT(*) FROM 表名\\\"));  // 得到數(shù)據(jù)庫(kù)記錄條數(shù)
  _variant_t vtItemCount = m_OracleDataBase.get_collect_value(long(0));
  _bstr_t bsValue = vtItemCount;  // 將結(jié)果格式化為字符串
  ★// 14.遍歷數(shù)據(jù)庫(kù)所有內(nèi)容
  TCHAR szSQL[MAX_PATH];
  _stprintf(szSQL, _TEXT(\\\"SELECT * FROM %s\\\"), ptTableName);  // 格式化 SQL 語(yǔ)句
  m_OracleDataBase.execute_sql(szSQL);   // 執(zhí)行 SQL 語(yǔ)句
  m_OracleDataBase.first();  // 將游標(biāo)移動(dòng)到第一條數(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();   // 移動(dòng)到下一列
  }
  ★// 15.刪除當(dāng)前行
  m_OracleDataBase.del_collect_value();
  ★// 16.注冊(cè)數(shù)據(jù)庫(kù)
  COracleDataBaseCtrl::Configuration_DataBaseSource(DNS, 數(shù)據(jù)庫(kù)DB文件路徑, 描述);
  ★// 17.其它還有一些請(qǐng)參:OracleDataBaseCtrl.h 文件
  ★// 18.反注冊(cè) 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 導(dǎo)出的
class ORACLEDATABASECTRL_API COracleDataBaseCtrl {
public:
 COracleDataBaseCtrl(void);
 // TODO: 在此添加您的方法。
 ~COracleDataBaseCtrl();
 //****************************************************************************
private:
 _ConnectionPtr m_pConnection;
 _RecordsetPtr m_pRecordset;
 HRESULT hr;
 //****************************************************************************
public:
 // 打開數(shù)據(jù)庫(kù)
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT open_database(PCTSTR pctsUser, PCTSTR pctsPass, PCTSTR pctsServer, long Options = adModeUnknown);
 // 斷開數(shù)據(jù)庫(kù)
 // 用 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);
 // 遍歷所有表名(第一個(gè))
 // 參數(shù):ptTableName [OUT]  遍歷到的表名
 // 注意:if (lstrcmp(ptTableName, _TEXT(\\\"\\\")) != 0 ) 表名才有效
 // 返回:false 出錯(cuò)或遍歷完畢
 bool first_table_name(PTSTR &ptsTableName);
 // 遍歷所有表名(下一個(gè))
 // 參數(shù):ptTableName [OUT]  遍歷到的表名
 // 注意:if (lstrcmp(ptTableName, _TEXT(\\\"\\\")) != 0 ) 表名才有效
 // 返回:false 出錯(cuò)或遍歷完畢
 bool next_table_name(PTSTR &ptsTableName);
 //****************************************************************************
 // 執(zhí)行 SQL 語(yǔ)句
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT execute_sql(PCTSTR pctsSQL, long Options = adCmdText);
 // 是否到記錄集末端(0--沒(méi)有,1--是 -1--錯(cuò)誤)
 int Is_BOF(void);
 // 跳向前一個(gè)記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT prev(void);
 // 遍歷到第一個(gè)記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT first(void);
 // 遍歷到下個(gè)記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT next(void);
 // 遍歷到最后一個(gè)記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT last(void);
 // 更新(確認(rèn))記錄
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT update(void);
 // 重新查詢
 // 用 SUCCEEDED 或 FAILED 判斷返回值
 HRESULT reQuery(long Options = 0);
 // 記錄集是否為空(0--沒(méi)有,1--是 -1--錯(cuò)誤)
 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ù)(當(dāng)前)
 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)用程序的入口點(diǎn)。
//
#include \\\"stdafx.h\\\"
#include \\\"OracleDataBaseCtrl.h\\\"

//****************************************************************************
// 數(shù)據(jù)庫(kù)表名
TCHAR * pszTableName;
// 數(shù)據(jù)庫(kù)字段名
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()
{
 // 反注冊(cè)COM
 CoUninitialize();
 if (pszTableName != NULL) free(pszTableName);
 if (pszFieldName != NULL) free(pszFieldName);
}

支持(0中立(0反對(duì)(0單帖管理 | 引用 | 回復(fù) 回到頂部

返回版面帖子列表

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








簽名
毛片网站在线看_天堂俺去俺来也www久久婷婷_日韩av免费网站_18性欧美xxxⅹ性满足_一区二区三区韩国免费中文网站 _性xx色xx综合久久久xx_999亚洲国产精
精品嫩草影院久久| 在线精品视频一区二区三四| 国产一本一道久久香蕉| 欧美特级限制片免费在线观看| 久久久www成人免费无遮挡大片| 日韩av不卡在线观看| 欧美日韩aaaaaa| 日韩成人精品视频| 日韩精品自拍偷拍| 精品一区二区三区日韩| 久久综合丝袜日本网| 国产成人精品亚洲午夜麻豆| 国产精品美女久久久久av爽李琼| 成人免费视频网站在线观看| 亚洲视频在线一区| 欧美日本乱大交xxxxx| 免费在线观看日韩欧美| 久久精品在线免费观看| 色综合视频在线观看| 亚洲高清在线视频| 日韩三级av在线播放| 国产激情91久久精品导航| 中文字幕不卡在线观看| 在线观看日韩av先锋影音电影院| 日本成人中文字幕在线视频| 国产偷国产偷精品高清尤物| 91免费看`日韩一区二区| 亚洲福利视频导航| 久久精品网站免费观看| 99re热视频精品| 视频一区二区欧美| 国产欧美日韩中文久久| 99久久精品国产麻豆演员表| 亚洲图片欧美视频| 久久精品水蜜桃av综合天堂| 欧美午夜不卡在线观看免费| 精品无人码麻豆乱码1区2区| 亚洲欧美一区二区久久| 欧美xxxx老人做受| 91网页版在线| 国产黑丝在线一区二区三区| 五月综合激情网| 亚洲欧洲成人自拍| 久久婷婷久久一区二区三区| 欧美中文字幕一二三区视频| 国产一区在线看| 午夜伦理一区二区| 中文字幕亚洲一区二区va在线| 91精品国产综合久久久久久| 91香蕉视频污在线| 国产一区二区福利视频| 午夜视频在线观看一区| 亚洲三级电影全部在线观看高清| 欧美v国产在线一区二区三区| 欧美日韩一区国产| bt欧美亚洲午夜电影天堂| 久久99精品国产.久久久久| 亚洲一区电影777| 亚洲精品国产高清久久伦理二区 | 国产精品国产三级国产专播品爱网 | 一区二区三区视频在线看| 国产午夜精品美女毛片视频| 91精品免费在线| 欧美精品一二三四| 欧美日韩aaaaa| 欧美精品久久99| 欧美日韩国产一级片| 欧美色图片你懂的| 欧美一a一片一级一片| 97久久精品人人做人人爽 | 国产激情91久久精品导航 | 亚洲午夜精品网| 亚洲午夜电影在线| 亚洲丶国产丶欧美一区二区三区| **性色生活片久久毛片| 中文字幕一区二区视频| 国产欧美1区2区3区| 中文av字幕一区| 亚洲视频 欧洲视频| 亚洲最新视频在线观看| 亚洲成人免费在线观看| 亚洲丶国产丶欧美一区二区三区| 亚洲午夜羞羞片| 奇米色一区二区| 精品伊人久久久久7777人| 精品在线免费观看| 粉嫩在线一区二区三区视频| www.av精品| 欧美亚洲动漫精品| 欧美一二三四区在线| 久久久亚洲高清| 国产精品无遮挡| 亚洲一区二区精品视频| 青青草精品视频| 国产黄色成人av| 在线观看日产精品| 久久一区二区视频| 国产精品国产自产拍高清av王其| 综合分类小说区另类春色亚洲小说欧美| 亚洲欧美日本韩国| 久热成人在线视频| 99精品久久久久久| 欧美一二三在线| 亚洲少妇30p| 亚洲亚洲精品在线观看| 国产综合久久久久影院| 色综合久久综合中文综合网| 日韩欧美高清dvd碟片| 日韩一区中文字幕| 久久精工是国产品牌吗| av亚洲精华国产精华精| 91精品国产麻豆国产自产在线| 国产欧美一区视频| 天天色 色综合| 色哟哟欧美精品| 国产色一区二区| 日韩电影免费一区| 欧洲亚洲精品在线| 欧美激情中文不卡| 蜜桃视频免费观看一区| 91在线观看视频| 日本一区二区综合亚洲| 精彩视频一区二区| 欧美精品丝袜中出| 亚洲精品免费在线| 国产成人精品一区二| 日韩欧美一二三区| 日韩精品91亚洲二区在线观看| 不卡一区二区在线| 国产欧美综合在线观看第十页| 日韩高清在线一区| 欧美日韩的一区二区| 亚洲综合无码一区二区| 91免费视频观看| 国产精品精品国产色婷婷| 国产一区二区电影| 精品国产污网站| 激情成人午夜视频| 欧美精品一区二区三区一线天视频| 亚洲6080在线| 欧美日韩国产综合久久| 亚洲国产美女搞黄色| 91久久精品日日躁夜夜躁欧美| 自拍av一区二区三区| a级精品国产片在线观看| 久久久久青草大香线综合精品| 狠狠色丁香婷婷综合| 欧美精品一区二区三区很污很色的| 日韩电影免费一区| 欧美一区二区播放| 激情亚洲综合在线| 国产欧美视频在线观看| 不卡av在线免费观看| 中文字幕制服丝袜成人av| www.日本不卡| 亚洲狠狠爱一区二区三区| 欧美日韩国产精选| 日韩高清不卡在线| 久久久高清一区二区三区| 国产成人午夜电影网| 国产精品三级在线观看| 波多野结衣视频一区| 亚洲精品成a人| 4438x亚洲最大成人网| 麻豆免费看一区二区三区| 亚洲精品一区二区三区福利| 成人免费av网站| 亚洲观看高清完整版在线观看| 欧美一区二区免费观在线| 国产一区二区导航在线播放| 综合久久久久久久| 91精品国产欧美日韩| 国产成人av影院| 一区二区三区久久久| 日韩一本二本av| 成人av网站在线| 天天色图综合网| 国产精品美日韩| 欧美日韩国产成人在线免费| 国产大陆精品国产| 亚洲成人综合在线| 2021久久国产精品不只是精品| av亚洲精华国产精华精华| 亚洲chinese男男1069| 久久久亚洲精华液精华液精华液| 色综合欧美在线视频区| 国产一区在线精品| 亚洲一区二区在线播放相泽| 久久亚洲私人国产精品va媚药| 色婷婷综合久久久久中文一区二区| 麻豆传媒一区二区三区| 一区二区久久久久久| 中日韩免费视频中文字幕| 欧美日韩一区久久| 91亚洲精华国产精华精华液| 精品一区二区免费| 奇米色一区二区三区四区| 午夜精品爽啪视频| 一区二区免费看| 亚洲免费观看在线观看|