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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? odb.cpp

?? 用C語(yǔ)言寫的一個(gè)數(shù)據(jù)庫(kù)
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
	if (m_po->hpSelect)
		OCIHandleFree( m_po->hpSelect, OCI_HTYPE_STMT );

	// Detach server from server handle
	if (m_po->hpErr)
		OCIServerDetach( m_po->hpServer, m_po->hpErr, OCI_DEFAULT );

	// Free server handle
	if (m_po->hpServer)
		CheckErr( OCIHandleFree(m_po->hpServer, OCI_HTYPE_SERVER) );

	// Free service context
	if (m_po->hpContext)
		OCIHandleFree( m_po->hpContext, OCI_HTYPE_SVCCTX);

	// Free error handle
	if (m_po->hpErr)
		OCIHandleFree( m_po->hpErr, OCI_HTYPE_ERROR );

	/* add by lf */
	Exec_After();

	TRACE("\n Oracle Database Closed!");
	m_po->Clear();
	return m_po->hr;
}

HRESULT COdb::Exec_Do( const CString csStatement, BOOL bNeedCommit )
{
	//
	// Execute statement
	//
	m_csLog += csStatement + "\n";

	// Allocate statement handle
	OCIStmt *hpStatement = NULL;
	CheckErr( OCIHandleAlloc( m_po->hpEnv,		// environment handle
		(void**)&hpStatement,					// return handle
		OCI_HTYPE_STMT,							// specifies generation of statement
		0,										// amount of user memory
		NULL )									// Returns pointer to user memory
		);

	// Associate statement string with handle
	CString csCleanStatement = csStatement;
	CleanWhitespace( csCleanStatement );
	CheckErr( OCIStmtPrepare( hpStatement,		// statement handle
		m_po->hpErr,							// error handle
		(text *)csCleanStatement.GetBuffer(0),	// statement
		csCleanStatement.GetLength(),			// length of statement
		OCI_NTV_SYNTAX,							// specify native syntax
		OCI_DEFAULT )							// default mode
		);

	// Execute statement
	CheckErr( OCIStmtExecute( m_po->hpContext,	// context handle
		hpStatement,							// statement handle
		m_po->hpErr,							// error handle
		(ub4) 1,								// number of times statement executed for non-Select statements
		(ub4) 0,								// row offset	// starting index of data
		(CONST OCISnapshot *) NULL,				// snapshot descriptor
		(OCISnapshot *) NULL,					// pointer to snapshot descriptor
		OCI_DEFAULT )
		);

	// Commit the change
	if(bNeedCommit == TRUE)
		CheckErr( OCITransCommit(m_po->hpContext, m_po->hpErr, 0));

	// Free statement handle
	if ( hpStatement )
		OCIHandleFree( hpStatement, OCI_HTYPE_STMT );

	return m_po->hr;
}

HRESULT COdb::Exec_Before( void )
{
	// Allocate statement handle
	CheckErr( OCIHandleAlloc( m_po->hpEnv,		// environment handle
		(void**)&m_po->hpStatement,				// return handle
		OCI_HTYPE_STMT,							// specifies generation of statement
		0,										// amount of user memory
		NULL )									// Returns pointer to user memory
		);

	return m_po->hr;
}

HRESULT COdb::Exec( CString csStatement, BOOL bNeedCommit )
{
	// Associate statement string with handle
	CString csCleanStatement = csStatement;
	CleanWhitespace( csCleanStatement );
	CheckErr( OCIStmtPrepare( m_po->hpStatement,// statement handle
		m_po->hpErr,							// error handle
		(text *)csCleanStatement.GetBuffer(0),	// statement
		csCleanStatement.GetLength(),			// length of statement
		OCI_NTV_SYNTAX,							// specify native syntax
		OCI_DEFAULT )							// default mode
		);

	// Execute statement
	CheckErr( OCIStmtExecute( m_po->hpContext,	// context handle
		m_po->hpStatement,						// statement handle
		m_po->hpErr,							// error handle
		(ub4) 1,								// number of times statement executed for non-Select statements
		(ub4) 0,								// row offset	// starting index of data
		(CONST OCISnapshot *) NULL,				// snapshot descriptor
		(OCISnapshot *) NULL,					// pointer to snapshot descriptor
		OCI_DEFAULT )
		);

	// Commit the change
	if(bNeedCommit == TRUE)
		CheckErr( OCITransCommit(m_po->hpContext, m_po->hpErr, 0));

	return m_po->hr;
}

HRESULT COdb::Exec_After( void )
{
	// Free statement handle
	if ( m_po->hpStatement )
		OCIHandleFree( m_po->hpStatement, OCI_HTYPE_STMT );

	return m_po->hr;
}

HRESULT COdb::Select( const CString csStatement )
{
	//
	// Execute select statement and parse the select list description
	// Use member recordset rsSelect
	// See also Get, FetchNext, IsEOS
	//
	m_csLog += csStatement + "\n";

	// Free previous select handle and remove fields
	m_po->rsSelect.m_nRows = 0;
	m_po->rsSelect.RemoveAll();
	if (m_po->hpSelect)
		OCIHandleFree( m_po->hpSelect, OCI_HTYPE_STMT );

	// Allocate statement handle
	CheckErr( OCIHandleAlloc( m_po->hpEnv,
		(void**)&m_po->hpSelect,	// ref to statement handle pointer
		OCI_HTYPE_STMT,				// type of handle being allocated
		0,
		NULL )
		);

	// Associate statement string with handle
	m_po->rsSelect.m_csStatement = csStatement;
	CleanWhitespace( m_po->rsSelect.m_csStatement );
	CheckErr( OCIStmtPrepare( m_po->hpSelect,
		m_po->hpErr,		// error handle pointer
		(text *)m_po->rsSelect.m_csStatement.GetBuffer(0), // statement string
		m_po->rsSelect.m_csStatement.GetLength(),
		OCI_NTV_SYNTAX,		// specify native syntax
		OCI_DEFAULT )
		);

	// Execute but don't fetch yet
	CheckErr( OCIStmtExecute( m_po->hpContext,	// context handle
		m_po->hpSelect, 
		m_po->hpErr,							// error handle
		(ub4) 0,								// iters
		(ub4) 0,								// max rows to fetch during this call
		(CONST OCISnapshot *) NULL,				// snapshot descriptor
		(OCISnapshot *) NULL,					// pointer to snapshot descriptor
		OCI_DEFAULT )
		);

	// If it returns OCI_NO_DATA then no need to define recordset
	if ( m_po->hr == OCI_NO_DATA || FAILED(m_po->hr) )
	{
		return m_po->hr;
	}

	// Load the types into recordset
	int nColumnCount = 0;
	while ( m_po->hr == OCI_SUCCESS )
	{
		// Get pointer to column
		void* pFieldAttr = NULL;
		HRESULT hrGetNext;
		hrGetNext = OCIParamGet( m_po->hpSelect, OCI_HTYPE_STMT,
			m_po->hpErr,
			&pFieldAttr,
			nColumnCount+1 // position
			);
		if ( hrGetNext != OCI_SUCCESS )
			break;

		// Increment column count and allocate an OdbField structure
		++nColumnCount;
		OdbField* pField = new OdbField;
		m_po->rsSelect.paFields.Add( pField );

		// Get data type
		CheckErr( OCIAttrGet( pFieldAttr, OCI_DTYPE_PARAM,
			&pField->wType,
			0,
			OCI_ATTR_DATA_TYPE,
			m_po->hpErr )
			);

		// Get data size
		CheckErr( OCIAttrGet( pFieldAttr, OCI_DTYPE_PARAM,
			&pField->wSize,
			0,
			OCI_ATTR_DATA_SIZE,
			m_po->hpErr )
			);

		// Type conversions
		if ( pField->wType == SQLT_LNG )
		{
			// LONG size
			pField->wSize = 32760;
		}
		else if ( pField->wType == SQLT_DAT )
		{
			// String is bound to DATE
			pField->wType = SQLT_STR;
			pField->wSize = 50;
		}
		else if ( pField->wType == SQLT_NUM )
		{
			// String is bound to NUMBER
			pField->wType = SQLT_STR;
			pField->wSize += 1; // allow for null-terminator
		}

		// Get column name
		text* pName;
		ub4 nNameLen;
		CheckErr( OCIAttrGet( pFieldAttr, OCI_DTYPE_PARAM,
			(void**)&pName,
			&nNameLen,
			OCI_ATTR_NAME,
			m_po->hpErr )
			);

		// Set size and name
		pField->SetSize( pField->wSize );
		pField->csName.Format( "%.*s", nNameLen, pName );
	}

	// Bind storage for receiving input variables
	OCIDefine *pDefn;	// to hold pointer to field definition
	int iField;
	for ( iField=0; iField<m_po->rsSelect.paFields.GetSize(); ++iField )
	{
		// Get pointer to field structure
		OdbField* pField = (OdbField*)m_po->rsSelect.paFields[iField];

		// Bind
		pDefn = NULL;
		CheckErr( OCIDefineByPos( m_po->hpSelect,
			&pDefn,				// function allocs and gives back a pointer to field definition
			m_po->hpErr,
			iField+1,			// position in select starting at 1
			pField->pBuffer,	// storage area for field result
			pField->wSize,		// sizeof storage area
			pField->wType,		// field type
			&pField->nInd,		// indp, null indicator
			&pField->wLen,		// rlenp
			NULL,
			OCI_DEFAULT )
			);
	}

	// Fetch
	FetchNext();

	return m_po->hr;
}

HRESULT COdb::FetchNext()
{
	//
	// Fetch next row of select statement and parse the select list description
	//
	CheckErr( OCIStmtFetch( m_po->hpSelect,
		m_po->hpErr,
		1,									// number of rows to be fetched
		OCI_FETCH_NEXT, 					// the only value in Oracel 8
		OCI_DEFAULT )
		);

	// Set result to 0 if no data returned
	m_csResults = "";
	m_po->rsSelect.m_nRows = 0;
	if ( SUCCEEDED(m_po->hr) && m_po->hr != OCI_NO_DATA )
	{
		// Set number of rows to 1 so IsEOS() will fail
		m_po->rsSelect.m_nRows = 1;

		/* attention: not get result cstring */
	}

	return m_po->hr;
}

HRESULT COdb::FetchMultiNext( int num )
{
	//
	// Fetch next row of select statement and parse the select list description
	//

	CheckErr( OCIStmtFetch( m_po->hpSelect,
		m_po->hpErr,
		num,								// number of rows to be fetched
		OCI_FETCH_NEXT, 					// the only value in Oracel 8
		OCI_DEFAULT )
		);

	// Set result to 0 if no data returned
	m_po->rsSelect.m_nRows = 0;
	if ( SUCCEEDED(m_po->hr) && m_po->hr != OCI_NO_DATA )
	{
		// Set number of rows to 1 so IsEOS() will fail
		m_po->rsSelect.m_nRows = 1;

		/* attention: not get result cstring */
	}

	return m_po->hr;
}


BOOL COdb::IsEOS()
{
	//
	// Return FALSE if m_nRows is 1, otherwise TRUE
	//
	BOOL bIsEOS = TRUE;
	if ( m_po->rsSelect.m_nRows )
		bIsEOS = FALSE;
	return bIsEOS;
}

CString COdb::GetField( int iField )
{
	//
	// Return string from indexed field in rsSelect
	//
	if ( iField >= 0 && iField < m_po->rsSelect.paFields.GetSize() )
	{
		OdbField* pField= (OdbField*)m_po->rsSelect.paFields.GetAt( iField );
		return pField->Get();
	}
	return "";
}

CString COdb::GetField( CString csName )
{
	//
	// Return string from named field in rsSelect
	//
	for ( int iField = 0; iField < m_po->rsSelect.paFields.GetSize(); ++iField )
	{
		OdbField* pField= (OdbField*)m_po->rsSelect.paFields.GetAt( iField );
		if ( pField->csName.CompareNoCase(csName) == 0 )
			return pField->Get();
	}
	return "";
}

CString COdb::GetMultiRowField( CString csName, int Row )
{
	//
	// Return string from named field in rsSelect
	//
	for ( int iField = 0; iField < m_po->rsSelect.paFields.GetSize(); ++iField )
	{
		OdbField* pField= (OdbField*)m_po->rsSelect.paFields.GetAt( iField );
		if ( pField->csName.CompareNoCase(csName) == 0 )
			return pField->GetMultiRow( Row );
	}
	return "";
}

BOOL COdb::GetField( int iField, CString& csName, CString& csValue, BOOL bQuotesIfValueRequires )
{
	//
	// Return TRUE if iField in range, otherwise FALSE if iField is invalid
	// Get name and value, surround value with quotes if flag set
	//
	if ( iField >= 0 && iField < m_po->rsSelect.paFields.GetSize() )
	{
		OdbField* pField= (OdbField*)m_po->rsSelect.paFields.GetAt( iField );
		if ( bQuotesIfValueRequires && pField->bQuotedOnUpdate )
			csValue = "'" + ProcessQuotes(pField->Get()) + "'";
		else
			csValue = pField->Get();
		csName = pField->csName;
		return TRUE;
	}
	return FALSE;
}

void COdb::CleanWhitespace( CString& csStatement )
{
	//
	// Sometimes crlfs can make a statement execute improperly
	// Replace whitespace with spaces because Exec and Select balk at crlfs etc
	//
	char* pStatement = csStatement.GetBuffer(0);
	while ( *pStatement )
	{
		if ( strchr( "\r\n\t", *pStatement ) )
			*pStatement = ' ';
		++pStatement;
	}
	csStatement.ReleaseBuffer();
}

CString COdb::ProcessQuotes( CString csValue )
{
	//
	// If there is any chance the value contains quotes...
	// call this before placing quotes around the value
	//
	LPCTSTR szQuote = "\'";

	// Does the string contain any single quotes?
	if ( csValue.Find( szQuote ) >= 0 )
	{
		// Loop through every occurence of szQuote
		int n = csValue.SpanExcluding(szQuote).GetLength();
		while ( n < csValue.GetLength() )
		{
			// Insert the extra quote
			csValue = csValue.Left(n) + csValue[n] + csValue.Mid(n);

			// Increment n past the two quotes
			// This is where we start the next search from
			n += 2;

			// Note that csValue is now a char longer!
			// Check in case quote was the last char in the string
			if ( n >= csValue.GetLength() )
				break;

			// Increment span count to next quote or end of string
			n += csValue.Mid(n).SpanExcluding(szQuote).GetLength();
		}
	}

	return csValue;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人午夜电影| 欧美一级搡bbbb搡bbbb| 91丨九色丨蝌蚪丨老版| 欧美性猛交xxxx黑人交| 4438x亚洲最大成人网| 精品国精品国产尤物美女| 久久嫩草精品久久久精品| 欧美激情综合五月色丁香小说| 一区视频在线播放| 视频一区二区不卡| 国产精品自拍一区| 91麻豆国产精品久久| 久久综合五月天婷婷伊人| 亚洲日本va午夜在线电影| 亚洲国产精品久久久久婷婷884| 免费观看日韩电影| www.久久久久久久久| 欧美日韩国产大片| 国产日韩三级在线| 午夜精品在线看| 大胆欧美人体老妇| 欧美一区二区三区不卡| 亚洲成人一二三| 一本一道久久a久久精品| 精品国产乱码久久| 日本午夜精品视频在线观看| 懂色av中文一区二区三区| 欧美精品久久久久久久多人混战| 中文字幕欧美日本乱码一线二线| 精品中文字幕一区二区小辣椒| 91美女在线看| 国产精品成人在线观看| 日本成人超碰在线观看| 欧美日韩国产首页| 午夜伊人狠狠久久| 欧美日韩一区二区三区四区| 国产精品第13页| 成人性生交大合| 国产精品家庭影院| 不卡的av电影| 久久天天做天天爱综合色| 极品少妇一区二区三区精品视频 | 日韩va欧美va亚洲va久久| 欧美性xxxxxx少妇| 亚洲综合视频网| 成人激情视频网站| 国产精品乱码久久久久久| 麻豆精品精品国产自在97香蕉| 色综合天天狠狠| 精品免费国产一区二区三区四区| 亚洲国产日韩一级| 91在线一区二区| 久久久欧美精品sm网站| 九九视频精品免费| 日韩欧美国产系列| 国产精品美女久久久久aⅴ国产馆| 国内精品国产三级国产a久久| 91在线无精精品入口| 成人欧美一区二区三区白人| 懂色av一区二区三区蜜臀| 国产精品久久久久影院| 成人免费视频网站在线观看| 国产蜜臀97一区二区三区| 国产精品1区2区3区在线观看| 久久综合色一综合色88| 国产一区二区三区免费看| 久久精品人人爽人人爽| 国产精品第13页| 91污在线观看| 亚洲欧洲综合另类| 国产精品一区三区| 欧美激情一区在线观看| 不卡一区二区中文字幕| 一区二区三区四区视频精品免费| 欧美一a一片一级一片| 午夜精品123| 欧美videossexotv100| 韩国欧美一区二区| 欧美国产视频在线| 91视视频在线直接观看在线看网页在线看 | 最新国产精品久久精品| 色综合久久久久久久久| 依依成人综合视频| 国产一区二区三区国产| 久久九九国产精品| 91美女片黄在线观看| 午夜欧美2019年伦理| 精品欧美乱码久久久久久1区2区| 国产高清在线精品| 5566中文字幕一区二区电影| 男人的j进女人的j一区| 久久午夜免费电影| 99re热这里只有精品视频| 亚洲一区二区三区在线| 欧美电影免费观看高清完整版| 国产精品亚洲成人| 日韩美女视频19| 日韩欧美高清dvd碟片| 国产精品一区在线观看你懂的| 国产精品高清亚洲| 欧美三区免费完整视频在线观看| 另类成人小视频在线| 国产精品久久久99| 欧美日本不卡视频| 国产乱人伦偷精品视频免下载| 亚洲免费在线看| 欧美区一区二区三区| 国内精品国产成人国产三级粉色| 亚洲人成在线播放网站岛国| 91精品综合久久久久久| 国产成人免费视频| 午夜激情一区二区| 国产欧美精品一区aⅴ影院| 欧美丝袜丝交足nylons| 青青草成人在线观看| 亚洲视频电影在线| 日韩欧美激情四射| 色欲综合视频天天天| 久久av资源网| 亚洲激情欧美激情| 久久久精品黄色| 欧美日韩欧美一区二区| 成人综合激情网| 一区二区三区在线观看动漫| 国产精品久久久久久久午夜片| 555www色欧美视频| 91免费精品国自产拍在线不卡| 久久不见久久见免费视频1| 夜夜爽夜夜爽精品视频| 国产日韩欧美综合在线| 欧美精品在线视频| 91啪九色porn原创视频在线观看| 麻豆久久一区二区| 一区二区三区成人在线视频| 久久久另类综合| 欧美一区二区久久| 在线观看三级视频欧美| 福利电影一区二区三区| 久久精品噜噜噜成人av农村| 亚洲综合色网站| 国产精品丝袜在线| 精品毛片乱码1区2区3区| 在线观看一区二区精品视频| 色综合久久久久网| 成人美女视频在线看| 精品一二三四区| 日韩影院精彩在线| 亚洲综合色自拍一区| 亚洲天堂成人在线观看| 国产日韩欧美在线一区| 日韩精品自拍偷拍| 日韩欧美中文字幕公布| 免费看精品久久片| 亚洲黄色免费电影| 专区另类欧美日韩| 国产精品三级av| 久久久亚洲精华液精华液精华液| 欧美猛男gaygay网站| 在线成人av影院| 欧美色倩网站大全免费| 色婷婷综合久久久久中文一区二区 | 欧美亚男人的天堂| 99久久精品免费| 成人免费看的视频| 国产盗摄精品一区二区三区在线| 久久精品久久99精品久久| 亚洲国产综合91精品麻豆| 亚洲午夜精品在线| 亚洲成在线观看| 亚洲第一搞黄网站| 亚洲成人免费视频| 午夜一区二区三区在线观看| 一区二区三区美女| 一区二区三区中文字幕精品精品| 一区精品在线播放| 国产精品久久久久aaaa樱花 | 国产91露脸合集magnet| 成人免费毛片a| 91在线观看下载| 色综合天天综合给合国产| 99re视频精品| 在线观看亚洲专区| 欧美日韩国产一级片| 91精品国产综合久久久久久久| 欧美手机在线视频| 精品国产免费视频| 久久一夜天堂av一区二区三区| 国产视频一区不卡| 国产精品国产精品国产专区不蜜| **欧美大码日韩| 一区二区三区久久| 亚洲sss视频在线视频| 亚洲欧美偷拍三级| 亚洲精品久久久蜜桃| 亚洲福利视频一区| 免费国产亚洲视频| 国产成人免费高清| 色综合久久综合| 欧美男女性生活在线直播观看| 日韩欧美在线观看一区二区三区|