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


曙海教育集團論壇開發語言培訓專區Oracle數據庫 → Oracle 數據庫常用方法封裝類


  共有9450人關注過本帖樹形打印

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

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


加好友 發短信
等級:青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊:2010-11-12 11:08:23
Oracle 數據庫常用方法封裝類  發帖心情 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)

// 配置數據源必須頭文件
#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);
}

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

返回版面帖子列表

Oracle 數據庫常用方法封裝類








簽名
毛片网站在线看_天堂俺去俺来也www久久婷婷_日韩av免费网站_18性欧美xxxⅹ性满足_一区二区三区韩国免费中文网站 _性xx色xx综合久久久xx_999亚洲国产精
国产午夜精品一区二区| 国产成人8x视频一区二区 | 色又黄又爽网站www久久| 日本不卡视频在线观看| 国产精品国产三级国产专播品爱网| 欧美揉bbbbb揉bbbbb| 国产91丝袜在线播放九色| 日韩福利电影在线| 亚洲一区av在线| 最近日韩中文字幕| 国产精品情趣视频| 国产精品三级在线观看| 国产日产欧美一区| 日韩免费性生活视频播放| 欧美片网站yy| 欧美日韩极品在线观看一区| bt7086福利一区国产| 久久99久久99小草精品免视看| 亚洲r级在线视频| 亚洲第一福利一区| 亚洲www啪成人一区二区麻豆 | 亚洲欧美日韩人成在线播放| 国产人成一区二区三区影院| 26uuu国产一区二区三区| 欧美日韩国产高清一区二区三区 | 色综合色狠狠天天综合色| 成人18视频日本| 97se亚洲国产综合自在线观| 91在线播放网址| 一本一道久久a久久精品 | 久久久夜色精品亚洲| 欧美一区二区黄色| 日韩美女主播在线视频一区二区三区| 欧美肥胖老妇做爰| 精品99久久久久久| 国产精品无人区| 一区二区三区四区中文字幕| 亚洲777理论| 精品久久久久99| 久久久久99精品一区| 国产精品久线在线观看| 亚洲一线二线三线视频| 日av在线不卡| 国产精品 欧美精品| 成人av手机在线观看| 色婷婷av一区| 欧美日高清视频| 欧美成人综合网站| 国产精品每日更新在线播放网址 | 日韩女优毛片在线| 2020国产精品久久精品美国| 国产精品传媒入口麻豆| 亚洲国产成人高清精品| 久久99精品久久久久久| 色婷婷av一区二区三区软件| 欧美tickling挠脚心丨vk| 综合久久一区二区三区| 蓝色福利精品导航| 99这里只有精品| 91精品国产综合久久国产大片| 久久久久一区二区三区四区| 亚洲国产精品综合小说图片区| 国产精品一区二区三区99| 欧美在线观看18| 国产亚洲成年网址在线观看| 日日夜夜精品视频天天综合网| 成人一区在线观看| 精品日韩一区二区| 爽好久久久欧美精品| heyzo一本久久综合| 精品国产髙清在线看国产毛片| 奇米影视在线99精品| 国产成人免费视频| 欧美精品少妇一区二区三区| 1024国产精品| 国产91综合网| 久久影院视频免费| 五月天国产精品| 色婷婷激情综合| 国产人久久人人人人爽| 丝袜亚洲另类欧美| 97se亚洲国产综合自在线观| 在线播放91灌醉迷j高跟美女| 色综合久久天天| 国产亚洲一区字幕| 午夜不卡在线视频| www.爱久久.com| 日韩一区二区免费电影| 亚洲精选一二三| 久久精品99久久久| 欧美无砖砖区免费| 国产精品久久久久久久久久久免费看| 亚洲123区在线观看| 不卡一区二区三区四区| 日韩欧美一区二区不卡| 亚洲r级在线视频| 成人av在线看| 久久日韩精品一区二区五区| 亚洲午夜视频在线| 成人一区二区在线观看| 欧美成人女星排行榜| 亚洲第一福利一区| 97久久精品人人澡人人爽| 26uuu色噜噜精品一区二区| 婷婷中文字幕综合| 成人av片在线观看| 91麻豆精品91久久久久久清纯| 亚洲欧洲www| 成人动漫中文字幕| 国产日本欧洲亚洲| 国产一区二区导航在线播放| 亚洲一区在线视频| 欧美精品vⅰdeose4hd| 亚洲成av人片在线观看无码| 91看片淫黄大片一级在线观看| 欧美国产欧美亚州国产日韩mv天天看完整| 免费在线观看成人| 日韩欧美一卡二卡| 石原莉奈在线亚洲三区| 欧美成人三级在线| 精品在线免费视频| 欧美成人精品福利| 激情国产一区二区| 久久精品亚洲精品国产欧美| 国产成人在线影院 | 91伊人久久大香线蕉| 自拍偷拍亚洲欧美日韩| 99视频在线精品| 一区二区三区蜜桃| 欧美色网站导航| 天堂一区二区在线| 91成人在线免费观看| 麻豆精品一区二区三区| 精品久久久久久久久久久久久久久久久 | 奇米色一区二区三区四区| 欧美精品久久久久久久多人混战| 视频一区在线播放| 欧美一区二区三区四区在线观看| 秋霞午夜鲁丝一区二区老狼| 精品国产一区二区三区四区四| 亚洲大型综合色站| 国产免费久久精品| 色婷婷亚洲精品| 日本强好片久久久久久aaa| 精品久久人人做人人爰| 国产精品亚洲一区二区三区妖精| 国产精品色在线观看| 欧美一区二区三区爱爱| 国产成人亚洲综合a∨婷婷图片 | 亚洲午夜电影在线观看| 精品日韩在线一区| 成人免费视频免费观看| 亚洲女人小视频在线观看| 欧美精品vⅰdeose4hd| 国产自产v一区二区三区c| 中文字幕av一区二区三区| 在线免费观看日本欧美| 国产乱理伦片在线观看夜一区| 国产精品久久久久久久蜜臀| 欧美午夜在线一二页| 久久电影国产免费久久电影| 国产精品久久久久久久久图文区| 欧美日韩国产一级二级| 国产精品一色哟哟哟| 亚洲mv在线观看| 国产欧美精品一区二区色综合| 成人av在线资源| 日韩高清欧美激情| 国产精品免费丝袜| 色香蕉成人二区免费| 成人爱爱电影网址| 免费在线欧美视频| 亚洲精品自拍动漫在线| 久久麻豆一区二区| 欧美日韩国产一区二区三区地区| 久久福利视频一区二区| 亚洲丝袜精品丝袜在线| 精品国产3级a| 色哦色哦哦色天天综合| 成a人片国产精品| 国内精品国产成人国产三级粉色 | 日韩av中文字幕一区二区三区| 亚洲欧美激情插| 中文字幕免费在线观看视频一区| 欧美一二三区精品| 欧美唯美清纯偷拍| 99riav久久精品riav| 国产在线看一区| 日韩在线a电影| 亚洲线精品一区二区三区八戒| 国产精品大尺度| 国产清纯白嫩初高生在线观看91 | 精品福利视频一区二区三区| 欧美三级日韩在线| 在线免费观看日本欧美| 99久久精品一区| 99精品黄色片免费大全| 高清久久久久久| 国产成人一区在线| 国产精品一区在线|