亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ociexampledlg.cpp

?? 這是書上的代碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// OCIExampleDlg.cpp : implementation file
//

#include "stdafx.h"
#include "OCIExample.h"
#include "OCIExampleDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// COCIExampleDlg dialog

COCIExampleDlg::COCIExampleDlg(CWnd* pParent /*=NULL*/)
	: CDialog(COCIExampleDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(COCIExampleDlg)
	m_strTablename = _T("");
	m_strFieldName = _T("");
	m_strcondition = _T("");
	m_strFieldVal = _T("");
	m_strConFName = _T("");
	m_strConFVal = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	//可以改變程序的圖標
	m_hIcon = AfxGetApp()->LoadIcon(IDR_ICON1);
	//初始化服務器句柄為空
	srvhp=NULL;
	//
	InsertDlg=NULL;
	//
	ColumnNumbers=0;
	//
	IsSizeInsertDlg=0;
}

void COCIExampleDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(COCIExampleDlg)
	DDX_Control(pDX, IDC_CO_CONFNAME, m_comConFNameCtrl);
	DDX_Control(pDX, IDC_COBFNAME, m_comboCtrl);
	DDX_Control(pDX, IDC_LIST_TABLEDATA, m_listCtrl);
	DDX_Control(pDX, IDC_LIST_TABLENAME, m_listTablename);
	DDX_LBString(pDX, IDC_LIST_TABLENAME, m_strTablename);
	DDX_CBString(pDX, IDC_COBFNAME, m_strFieldName);
	DDX_CBString(pDX, IDC_COMB_CONDITION, m_strcondition);
	DDX_Text(pDX, IDC_EFFIELDVAL, m_strFieldVal);
	DDX_CBString(pDX, IDC_CO_CONFNAME, m_strConFName);
	DDX_Text(pDX, IDC_E_CONFVAL, m_strConFVal);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(COCIExampleDlg, CDialog)
	//{{AFX_MSG_MAP(COCIExampleDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUT_CONNECTDB, OnButConnectdb)
	ON_BN_CLICKED(IDC_B_TABLESELECTOK, OnBTableselectok)
	ON_BN_CLICKED(IDC_BUT_QUERY, OnButQuery)
	ON_BN_CLICKED(IDC_BUT_DELETE, OnButDelete)
	ON_BN_CLICKED(IDC_BUT_UPDATE, OnButUpdate)
	ON_BN_CLICKED(IDC_BUT_INSERT, OnButInsert)
	ON_WM_SIZE()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// COCIExampleDlg message handlers

BOOL COCIExampleDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void COCIExampleDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void COCIExampleDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR COCIExampleDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void COCIExampleDlg::OnButConnectdb() 
{
	//OCIInitialize((ub4) OCI_DEFAULT,(dvoid *)0,(dvoid * (*)(dvoid *, size_t)) 0,
		//(dvoid * (*)(dvoid *, dvoid *, size_t)) 0,(void (*)(dvoid *, dvoid *)) 0 );
	/*
	OCIInitialize(OCI_OBJECT,(dvoid *)0,
                       (dvoid * (*)(dvoid *, size_t)) 0,
                       (dvoid * (*)(dvoid *, dvoid *, size_t)) 0,
                       (void (*)(dvoid *, dvoid *)) 0 );
					   */
	//ub4 mode = OCI_SHARED | OCI_THREADED;
	//代碼4.1.2
	//Initializes the OCI process environment
    OCIInitialize (OCI_OBJECT, 0, 0, 0, 0);
	//初始化OCI環境
	OCIEnvInit(&envhp,OCI_DEFAULT,0,0 );
    //代碼4.2.1:
	//分配句柄與數據結構
	//分配錯誤句柄
	OCIHandleAlloc(envhp,(void **)&errhp,OCI_HTYPE_ERROR,0,0);
    //分配服務器句柄
	OCIHandleAlloc(envhp,(void **)&srvhp,OCI_HTYPE_SERVER,0,0);
    //分配服務環境句柄
	OCIHandleAlloc(envhp,(void **)&svchp,OCI_HTYPE_SVCCTX,0,0);
	//分配會話句柄
	OCIHandleAlloc(envhp,(void **)&authp,OCI_HTYPE_SESSION,0,0);
	// allocate describe handle
    //分配描述句柄
    OCIHandleAlloc(envhp,(dvoid **) &dschp,OCI_HTYPE_DESCRIBE,0,0);
	//分配語句句柄
    ErrorProc(errhp,OCIHandleAlloc((dvoid *) envhp,(dvoid **) &stmthp,OCI_HTYPE_STMT,0,0));
	//代碼4.3.1
	//產生接收用戶數據的對話框
	CConectDlg  ConnDlg;
    ConnDlg.m_strDBName="imagedb";
    ConnDlg.m_strUserName="scott";
	ConnDlg.m_strUserID="tiger";
	if(ConnDlg.DoModal()==IDCANCEL)
		return;

	//代碼4.3.2
	// 連接數據庫
	UpdateData(TRUE);sword status;
    status=OCIServerAttach(srvhp,errhp,
		(unsigned char *)(LPCTSTR)ConnDlg.m_strDBName, 
		 (sb4)strlen(ConnDlg.m_strDBName),OCI_DEFAULT);
    // 設置數據庫的屬性:服務器環境
    ErrorProc(errhp,OCIAttrSet((dvoid *) svchp, 
                        (ub4) OCI_HTYPE_SVCCTX,
                      (dvoid *) srvhp, (ub4) 0, 
                      OCI_ATTR_SERVER, errhp));
	//代碼4.3.3,認證用戶并且開始會話
	LPCTSTR uid, pwd;
    uid=ConnDlg.m_strUserName;
    pwd=ConnDlg.m_strUserID;
	//認證用戶名稱;
    ErrorProc(errhp,OCIAttrSet(authp, 
	    OCI_HTYPE_SESSION, (dvoid *)uid, 
	  (ub4)strlen(uid),OCI_ATTR_USERNAME,errhp));	
    //認證用戶密碼
   ErrorProc(errhp,OCIAttrSet(authp, 
	     OCI_HTYPE_SESSION, (dvoid *)pwd, 
	     (ub4)strlen(pwd), OCI_ATTR_PASSWORD,errhp));	
    //以申明的用戶名稱與密碼開始會話 
   status=OCISessionBegin(svchp, errhp,
	  authp,OCI_CRED_RDBMS,OCI_DEFAULT);                            
    if(status!=0)
		return ;
	// set the Service context
    status=OCIAttrSet(svchp, (ub4)OCI_HTYPE_SVCCTX, 
	     (dvoid *)authp,0,OCI_ATTR_SESSION,errhp);		
     if(status!=0)
		 return;
	
	//代碼4.4.2
	//處理SQL的第一步,準備SQL
	//CString strSQL="SELECT TABLE_NAME FROM USER_TABLES";
	text textSQL[1024];
	wsprintf((char*)textSQL,"%s","SELECT TABLE_NAME FROM USER_TABLES");
	status=OCIStmtPrepare(stmthp,errhp,textSQL,
		strlen((char *)textSQL),OCI_NTV_SYNTAX,OCI_DEFAULT);
	//代碼4.4.3
	//處理SQL的第三步,執行
	status=OCIStmtExecute(svchp,stmthp,errhp,0,0,NULL,NULL,OCI_DEFAULT);

    //代碼4.4.4
    //處理SQL的第四步,描述
    ub4 col_num;//存放SELECT語句選中的列數
	//ub4 k=1;
	//讀取選擇列表中的項數
	ErrorProc(errhp,OCIAttrGet(stmthp,OCI_HTYPE_STMT,&col_num,0,
		OCI_ATTR_PARAM_COUNT,errhp));
    //為選擇項分配參數描述符
    ErrorProc(errhp,OCIParamGet(stmthp,OCI_HTYPE_STMT,errhp,(void **)&colhp,
			1));
    //讀取選擇項的數據長度
	ErrorProc(errhp,OCIAttrGet(colhp,OCI_DTYPE_PARAM,&collen[0],0,
		OCI_ATTR_DATA_SIZE,errhp));
    //讀取選擇項的數據類型
	ErrorProc(errhp,OCIAttrGet(colhp,OCI_DTYPE_PARAM,&coltype[0],0,
		OCI_ATTR_DATA_TYPE,errhp));
	//分配緩沖區
	colbuf[0]=(text *)new text[(int)collen[0]+1];
    
	//代碼4.4.5
	//處理SQL的第五步,定義變量
	status=OCIDefineByPos(stmthp,&defhp[0],errhp,1,(ub1*)colbuf[0],
		collen[0]+1,SQLT_STR,&ind[0],0,0,OCI_DEFAULT);


	//代碼4.4.6
    //處理SQL的第六步,取值
	while((OCIStmtFetch(stmthp,errhp,1,OCI_FETCH_NEXT,OCI_DEFAULT))!=OCI_NO_DATA)
	{
		//CString pass=colbuf[0];
        //if(pass.Find('$')==-1)
		//把獲取的用戶的基表的名稱加到ListBox控件中
		m_listTablename.AddString((char *)colbuf[0]);
	}
	//刪除所分配的緩沖區
    delete  colbuf[0];
	//使得選擇表的按鈕可用
	GetDlgItem(IDC_B_TABLESELECTOK )->EnableWindow(true);
}

BOOL COCIExampleDlg::DestroyWindow() 
{
	// TODO: Add your specialized code here and/or call the base class
  if(srvhp!=NULL)
  {
  //代碼4.5.1
  //結束會話
  OCISessionEnd(svchp, errhp, authp, (ub4) 0);
  //斷開與數據庫的連接
  OCIServerDetach(srvhp, errhp, OCI_DEFAULT);
  //釋放OCI句柄 
  OCIHandleFree((dvoid *) srvhp,  OCI_HTYPE_SERVER);
  OCIHandleFree((dvoid *) svchp,  OCI_HTYPE_SVCCTX);
  OCIHandleFree((dvoid *) errhp,  OCI_HTYPE_ERROR);
  OCIHandleFree((dvoid *) authp,  OCI_HTYPE_SESSION);
  OCIHandleFree((dvoid *) stmthp, OCI_HTYPE_STMT);
  OCIHandleFree((dvoid *) dschp,  OCI_HTYPE_DESCRIBE);
  }
	return CDialog::DestroyWindow();
}

void COCIExampleDlg::ErrorProc(dvoid *err, sword status)
{
	text errbuf[512];
	sb4  errcode;
	CString str;
	switch(status)
	{
	case OCI_SUCCESS:
		break;
	case OCI_SUCCESS_WITH_INFO:
		(void) AfxMessageBox("OCI錯誤代碼:OCI_SUCCESS_WITH_INFO\n");
		break;
	case OCI_NEED_DATA:
		(void) AfxMessageBox("OCI錯誤代碼:OCI_NEED_DATA\n");
		break;
	case OCI_NO_DATA:
		(void) AfxMessageBox("OCI錯誤代碼:OCI_NO_DATA\n");
		break;
	case OCI_ERROR:
		(void)OCIErrorGet((dvoid *)errhp,(ub4)1,NULL,&errcode,
			errbuf,(ub4)sizeof(errbuf),OCI_HTYPE_ERROR);
		str.Format("錯誤號:%d\n錯誤信息:%s\n",errcode,errbuf);
		AfxMessageBox(str);
		break;
	case OCI_INVALID_HANDLE:
		(void) AfxMessageBox("OCI錯誤代碼:OCI_INVALID_HANDLE\n");
		break;
	case OCI_STILL_EXECUTING:
		(void) AfxMessageBox("OCI錯誤代碼:OCI_STILL_EXECUTE\n");
		break;
	default:
		break;
	}

}
//代碼4.1.3,OCI錯誤報告函數
/*
ErrorProc(dvoid *err, sword status)
{
		
	CString str;sb4  errcode;text errbuf[512];
	if(status==OCI_ERROR)
	{
	//調用OCI的錯誤獲取函數
	OCIErrorGet((dvoid *)errhp,(ub4)1,NULL,&errcode,
			errbuf,(ub4)sizeof(errbuf),OCI_HTYPE_ERROR);
	str.Format("錯誤號:%d\n錯誤信息:%s\n",errcode,errbuf);
	AfxMessageBox(str);
	}
}


*/

COCIExampleDlg::~COCIExampleDlg()
{
	if(InsertDlg!=NULL)
      delete InsertDlg;
}

void COCIExampleDlg::OnBTableselectok() 
{
	// TODO: Add your control notification handler code here
	//代碼5.1,
    //獲取控件2所選中的表名
	TableName="";
    int item=m_listTablename.GetCurSel();
    m_listTablename.GetText(item,TableName);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月综合激情网| 久久久亚洲午夜电影| 亚洲精品久久7777| 一本高清dvd不卡在线观看| 亚洲女同ⅹxx女同tv| 91香蕉视频污在线| 亚洲小说春色综合另类电影| 91理论电影在线观看| 一区二区三区四区精品在线视频 | 一本色道a无线码一区v| 亚洲人成在线播放网站岛国| 欧美中文字幕亚洲一区二区va在线 | 亚洲va国产va欧美va观看| 91电影在线观看| 青草av.久久免费一区| 欧美精品一区二区三| 国产老妇另类xxxxx| 国产精品日日摸夜夜摸av| 97久久超碰国产精品| 一区二区三区国产精品| 欧美情侣在线播放| 久久99精品久久久| 中日韩免费视频中文字幕| 91在线视频网址| 无吗不卡中文字幕| 久久女同精品一区二区| 国产suv精品一区二区6| 一区二区三区四区国产精品| 日韩亚洲欧美高清| av爱爱亚洲一区| 亚洲国产你懂的| 日韩三级中文字幕| 91浏览器入口在线观看| 日本特黄久久久高潮| 久久久久久久久久久电影| 在线精品视频一区二区三四 | 国产在线精品一区二区不卡了| 国产视频一区在线观看| 欧美午夜电影一区| 国产一区二区电影| 艳妇臀荡乳欲伦亚洲一区| 久久综合色天天久久综合图片| av午夜一区麻豆| 青青草97国产精品免费观看 | 日本一区二区免费在线| 欧美色偷偷大香| 国内精品伊人久久久久影院对白| 亚洲欧美日韩系列| 精品国产一区二区三区久久影院 | 色综合久久久久久久| 亚洲一区二区三区在线看| ww亚洲ww在线观看国产| 欧美性猛片xxxx免费看久爱| 国产精品一区在线观看乱码| 日韩vs国产vs欧美| 国产精品成人免费| 国产欧美日韩中文久久| 91麻豆精品91久久久久久清纯 | 欧美三级三级三级| 成人黄色片在线观看| 日韩va亚洲va欧美va久久| 亚洲精品乱码久久久久| 中文一区二区完整视频在线观看| 4438x成人网最大色成网站| 91麻豆国产在线观看| 国产传媒一区在线| 久久成人麻豆午夜电影| 亚洲成在人线在线播放| 亚洲精品欧美激情| 国产精品国产三级国产aⅴ中文 | 精品视频一区三区九区| 99久久综合国产精品| 国产乱对白刺激视频不卡| 久久精品国产网站| 日韩高清电影一区| 亚洲国产综合人成综合网站| 亚洲欧美激情在线| 中文字幕一区二区三区色视频| 国产午夜精品久久久久久久 | 久久人人爽爽爽人久久久| 欧美精品乱码久久久久久| 在线视频国产一区| 99精品国产91久久久久久| 成人av电影在线播放| 99久久伊人久久99| 91一区二区三区在线播放| 97久久超碰国产精品| 色综合久久久久综合99| 色综合久久久久综合| 91成人网在线| 这里只有精品电影| 日韩一级二级三级| 久久久久亚洲综合| 中文字幕不卡在线| 中文字幕一区二区三区乱码在线| 亚洲另类在线一区| 香蕉久久一区二区不卡无毒影院| 午夜精品久久久久久久久久| 日韩主播视频在线| 老司机精品视频在线| 国产一区在线不卡| 成人网在线播放| 色欧美片视频在线观看| 欧洲精品一区二区| 91精品国产综合久久香蕉的特点| 欧美巨大另类极品videosbest | 欧美国产精品劲爆| 国产精品欧美久久久久一区二区| 亚洲精选视频免费看| 亚洲大片免费看| 久草精品在线观看| 国产91精品露脸国语对白| 91在线你懂得| 欧美三级一区二区| 久久久久久久久久久电影| 国产精品视频观看| 亚洲国产精品一区二区久久恐怖片 | 久久国产精品72免费观看| 丁香网亚洲国际| 在线免费观看一区| 日韩欧美色综合| 国产欧美视频一区二区| 亚洲一区二区五区| 国产一区二区美女诱惑| 91社区在线播放| 欧美一激情一区二区三区| 欧美激情综合在线| 午夜日韩在线电影| 国产91精品精华液一区二区三区 | 精品久久人人做人人爱| 国产女同性恋一区二区| 亚洲午夜在线视频| 狠狠色综合日日| 色94色欧美sute亚洲13| 精品欧美乱码久久久久久1区2区| 国产精品狼人久久影院观看方式| 免费人成黄页网站在线一区二区| 不卡一区二区在线| 91精品在线观看入口| 日韩一区在线免费观看| 麻豆精品视频在线| 在线亚洲一区二区| 久久久久久久综合日本| 日本不卡高清视频| 91在线国内视频| 久久久影视传媒| 天天综合色天天综合| 99久久精品国产麻豆演员表| 久久伊人蜜桃av一区二区| 一区二区三区精品视频在线| 大尺度一区二区| 精品三级在线看| 天天亚洲美女在线视频| 91热门视频在线观看| 国产日韩欧美在线一区| 免费人成在线不卡| 欧美老肥妇做.爰bbww| 亚洲女爱视频在线| 97久久精品人人澡人人爽| 中文字幕国产一区| 国产伦精一区二区三区| 日韩欧美另类在线| 日韩精品色哟哟| 欧美日韩国产综合一区二区| 椎名由奈av一区二区三区| 亚洲日穴在线视频| 国产精品久久精品日日| 精品一区二区三区久久久| 欧美美女一区二区三区| 亚洲国产精品人人做人人爽| 99精品黄色片免费大全| 国产精品国产三级国产普通话三级| 国产一区999| 久久久久青草大香线综合精品| 久久 天天综合| 精品国免费一区二区三区| 秋霞午夜鲁丝一区二区老狼| 欧美精品vⅰdeose4hd| 亚洲成av人片| 欧美精品777| 日日夜夜精品视频天天综合网| 在线91免费看| 麻豆91在线观看| 精品久久久久久久久久久院品网 | 精品制服美女丁香| 日韩一区二区在线观看| 久久成人免费电影| 2023国产精品视频| 成人国产亚洲欧美成人综合网| 亚洲欧洲av在线| 欧美艳星brazzers| 奇米精品一区二区三区四区| 国产亚洲精久久久久久| 99久久精品99国产精品| 亚洲第一搞黄网站| 2022国产精品视频| jlzzjlzz亚洲日本少妇| 天天av天天翘天天综合网色鬼国产| 日韩欧美一区在线| 成人黄色软件下载|