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

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

?? employees.cpp

?? EVC下OLEDB方法編寫的數據庫源代碼
?? CPP
?? 第 1 頁 / 共 5 頁
字號:

	// Release interfaces
	//
	if(pIDBProperties)
	{
		pIDBProperties->Release();
	}

    if (pIDBInitialize)
    {
        pIDBInitialize->Release();
    }

	return hr;
}

////////////////////////////////////////////////////////////////////////////////
// Function: ExecuteSQL
//
// Description:
//		Executes a non row returning SQL statement
//
// Parameters
//		pICmdText	- a pointer to the ICommandText interface on the Command Object
//		pwszQuery	- the SQL statement to execute
//
// Returns: NOERROR if succesfull
//
////////////////////////////////////////////////////////////////////////////////
HRESULT Employees::ExecuteSQL(ICommandText *pICmdText, WCHAR * pwszQuery)
{
	HRESULT hr = NOERROR;

	hr = pICmdText->SetCommandText(DBGUID_SQL, pwszQuery); 
	if(FAILED(hr))
	{
		goto Exit;
	}

	hr = pICmdText->Execute(NULL, IID_NULL, NULL, NULL, NULL);

Exit:

	return hr;
}


////////////////////////////////////////////////////////////////////////////////
// Function: InsertEmployeeInfo
//
// Description:	Inserts sample data
//
// Returns: NOERROR if succesfull
//
////////////////////////////////////////////////////////////////////////////////
HRESULT Employees::InsertEmployeeInfo()
{
	HRESULT				hr					= NOERROR;			// Error code reporting
	DBBINDING			*prgBinding			= NULL;				// Binding used to create accessor
    HROW				rghRows[1]          = {DB_NULL_HROW};   // Array of row handles obtained from the rowset object
	HROW				*prghRows			= rghRows;			// Row handle(s) pointer
	DBID				TableID;								// Used to open/create table
	DBID				IndexID;								// Used to create index
	DBPROPSET			rowsetpropset[1];						// Used when opening integrated index
	DBPROP				rowsetprop[1];							// Used when opening integrated index
   	ULONG				cRowsObtained		= 0;				// Number of rows obtained from the rowset object
    DBOBJECT			dbObject;								// DBOBJECT data.
	DBCOLUMNINFO		*pDBColumnInfo		= NULL;				// Record column metadata
	BYTE				*pData				= NULL;				// record data
	WCHAR				*pStringsBuffer		= NULL;
	DWORD				dwBindingSize		= 0;
	DWORD				dwIndex				= 0;
	DWORD				dwRow				= 0;
	DWORD				dwCol				= 0;
	DWORD				dwOffset			= 0;
	ULONG				ulNumCols;

	IOpenRowset			*pIOpenRowset		= NULL;				// Provider Interface Pointer
	IRowset				*pIRowset			= NULL;				// Provider Interface Pointer
	ITransactionLocal	*pITxnLocal			= NULL;				// Provider Interface Pointer
	IRowsetChange		*pIRowsetChange		= NULL;				// Provider Interface Pointer
	IAccessor			*pIAccessor			= NULL;				// Provider Interface Pointer
	ISequentialStream	*pISequentialStream = NULL;				// Provider Interface Pointer
	IColumnsInfo		*pIColumnsInfo		= NULL;				// Provider Interface Pointer
	HACCESSOR			hAccessor			= DB_NULL_HACCESSOR;// Accessor handle

	VariantInit(&rowsetprop[0].vValue);

	// Validate IDBCreateSession interface
	//
	if (NULL == m_pIDBCreateSession)
	{
		hr = E_POINTER;
		goto Exit;
	}

    // Create a session object 
    //
    hr = m_pIDBCreateSession->CreateSession(NULL, IID_IOpenRowset, (IUnknown**)&pIOpenRowset);
    if(FAILED(hr))
    {
        goto Exit;
    }

	hr = pIOpenRowset->QueryInterface(IID_ITransactionLocal, (void**)&pITxnLocal);
	if(FAILED(hr))
	{
		goto Exit;
	}

	// Set up information necessary to open a table 
	// using an index and have the ability to seek.
	//
	TableID.eKind			= DBKIND_NAME;
	TableID.uName.pwszName	= (WCHAR*)TABLE_EMPLOYEE;

	IndexID.eKind			= DBKIND_NAME;
	IndexID.uName.pwszName	= L"PK_Employees";

	// Request ability to use IRowsetChange interface
	// 
	rowsetpropset[0].cProperties	= 1;
	rowsetpropset[0].guidPropertySet= DBPROPSET_ROWSET;
	rowsetpropset[0].rgProperties	= rowsetprop;

	rowsetprop[0].dwPropertyID		= DBPROP_IRowsetChange;
	rowsetprop[0].dwOptions			= DBPROPOPTIONS_REQUIRED;
	rowsetprop[0].colid				= DB_NULLID;
	rowsetprop[0].vValue.vt			= VT_BOOL;
	rowsetprop[0].vValue.boolVal	= VARIANT_TRUE;

	// Open the table using the index
	//
	hr = pIOpenRowset->OpenRowset(	NULL,
									&TableID,
									&IndexID,
									IID_IRowset,
									sizeof(rowsetpropset)/sizeof(rowsetpropset[0]),
									rowsetpropset,
									(IUnknown**) &pIRowset);
	if(FAILED(hr))
	{
		goto Exit;
	}

    // Get IRowsetChange interface
	//
	hr = pIRowset->QueryInterface(IID_IRowsetChange, (void**)&pIRowsetChange);
	if(FAILED(hr))
	{
		goto Exit;
	}

    // Get IColumnsInfo interface
	//
    hr = pIRowset->QueryInterface(IID_IColumnsInfo, (void **)&pIColumnsInfo);
	if(FAILED(hr))
	{
		goto Exit;
	}

	// Get the column metadata 
	//
    hr = pIColumnsInfo->GetColumnInfo(&ulNumCols, &pDBColumnInfo, &pStringsBuffer);
	if(FAILED(hr) || 0 == ulNumCols)
	{
		goto Exit;
	}

    // Create a DBBINDING array.
    // The binding doesn't include the bookmark column (first column).
	//
	dwBindingSize = ulNumCols - 1;
	prgBinding = (DBBINDING*)CoTaskMemAlloc(sizeof(DBBINDING)*dwBindingSize);
	if (NULL == prgBinding)
	{
		hr = E_OUTOFMEMORY;
		goto Exit;
	}

	// Set initial offset for binding position
	//
	dwOffset = 0;

	// Prepare structures to create the accessor
	//
    for (dwIndex = 0; dwIndex < dwBindingSize; ++dwIndex)
    {
		prgBinding[dwIndex].iOrdinal	= pDBColumnInfo[dwIndex + 1].iOrdinal;
		prgBinding[dwIndex].pTypeInfo	= NULL;
		prgBinding[dwIndex].pBindExt	= NULL;
		prgBinding[dwIndex].dwMemOwner	= DBMEMOWNER_CLIENTOWNED;
		prgBinding[dwIndex].dwFlags		= 0;
		prgBinding[dwIndex].bPrecision	= pDBColumnInfo[dwIndex + 1].bPrecision;
		prgBinding[dwIndex].bScale		= pDBColumnInfo[dwIndex + 1].bScale;
		prgBinding[dwIndex].dwPart		= DBPART_VALUE | DBPART_STATUS | DBPART_LENGTH;
		prgBinding[dwIndex].obLength	= dwOffset;                                     
		prgBinding[dwIndex].obStatus	= prgBinding[dwIndex].obLength + sizeof(ULONG);  
		prgBinding[dwIndex].obValue		= prgBinding[dwIndex].obStatus + sizeof(DBSTATUS);

		switch(pDBColumnInfo[dwIndex + 1].wType)
		{
		case DBTYPE_BYTES:
			// Set up the DBOBJECT structure.
			//
			dbObject.dwFlags = STGM_WRITE;
			dbObject.iid = IID_ISequentialStream;

			prgBinding[dwIndex].pObject		= &dbObject;
			prgBinding[dwIndex].cbMaxLen	= sizeof(IUnknown*);
			prgBinding[dwIndex].wType		= DBTYPE_IUNKNOWN;
			break;

		case DBTYPE_WSTR:
			prgBinding[dwIndex].pObject		= NULL;
			prgBinding[dwIndex].wType		= pDBColumnInfo[dwIndex + 1].wType;
			prgBinding[dwIndex].cbMaxLen	= sizeof(WCHAR)*(pDBColumnInfo[dwIndex + 1].ulColumnSize + 1);	// Extra buffer for null terminator 
			break;

		default:
			prgBinding[dwIndex].pObject		= NULL;
			prgBinding[dwIndex].wType		= pDBColumnInfo[dwIndex + 1].wType;
			prgBinding[dwIndex].cbMaxLen	= pDBColumnInfo[dwIndex + 1].ulColumnSize; 
			break;
		}

		// Calculate new offset
		// 
		dwOffset = prgBinding[dwIndex].obValue + prgBinding[dwIndex].cbMaxLen;

		// Properly align the offset
		//
		dwOffset = ROUND_UP(dwOffset, COLUMN_ALIGNVAL);
	}

	// Get IAccessor interface
	//
	hr = pIRowset->QueryInterface(IID_IAccessor, (void**)&pIAccessor);
	if(FAILED(hr))
	{
		goto Exit;
	}

    // Create accessor.
	//
    hr = pIAccessor->CreateAccessor(DBACCESSOR_ROWDATA, 
									dwBindingSize, 
									prgBinding,
									0,
									&hAccessor,
									NULL);
    if(FAILED(hr))
    {
        goto Exit;
    }

	// Allocate data buffer for seek and retrieve operation.
	//
	pData = (BYTE*)CoTaskMemAlloc(dwOffset);
	if (NULL == pData)
	{
		hr = E_OUTOFMEMORY;
		goto Exit;
	}

	// Begins a new local transaction
	//
	hr = pITxnLocal->StartTransaction(ISOLATIONLEVEL_READCOMMITTED | ISOLATIONLEVEL_CURSORSTABILITY, 0, NULL, NULL);
	if(FAILED(hr))
	{
		goto Exit;
	}

	// Insert sample data
	//
	for (dwRow = 0; dwRow < sizeof(g_SampleEmployeeData)/sizeof(g_SampleEmployeeData[0]); ++dwRow)
	{
		DWORD	dwPhotoCol;
		DWORD   dwInfoSize;
		LPWSTR	lpwszInfo;

		// Set data buffer to zero
		//
		memset(pData, 0, dwOffset);

		for (dwCol = 0; dwCol < dwBindingSize; ++dwCol)
		{
			// Get column value in string
			//
			lpwszInfo = g_SampleEmployeeData[dwRow].wszEmployeeInfo[dwCol];

			switch(prgBinding[dwCol].wType)
			{
				case DBTYPE_WSTR:
					// Copy value to binding buffer, truncate the string if it is too long
					//
					dwInfoSize = prgBinding[dwCol].cbMaxLen/sizeof(WCHAR) - 1;
					if (wcslen(lpwszInfo) >= dwInfoSize)
					{
						wcsncpy((WCHAR*)(pData+prgBinding[dwCol].obValue), lpwszInfo, dwInfoSize);
						*(WCHAR*)(pData+prgBinding[dwCol].obValue+dwInfoSize*sizeof(WCHAR)) = WCHAR('\0');
					}
					else
					{
						wcscpy((WCHAR*)(pData+prgBinding[dwCol].obValue), lpwszInfo);
					}

					*(ULONG*)(pData+prgBinding[dwCol].obLength)		= wcslen((WCHAR*)(pData+prgBinding[dwCol].obValue))*sizeof(WCHAR);
					*(DBSTATUS*)(pData+prgBinding[dwCol].obStatus)	= DBSTATUS_S_OK;
					break;

				case DBTYPE_IUNKNOWN:
					dwPhotoCol = dwCol;
					break;

				case DBTYPE_I4:
					*(int*)(pData+prgBinding[dwCol].obValue)		= _wtoi(g_SampleEmployeeData[dwRow].wszEmployeeInfo[dwCol]);
					*(ULONG*)(pData+prgBinding[dwCol].obLength)		= 4;
					*(DBSTATUS*)(pData+prgBinding[dwCol].obStatus)	= DBSTATUS_S_OK;
					break;

				default:
					break;
			}
		}

		// Insert data to database
		//
		hr = pIRowsetChange->InsertRow(DB_NULL_HCHAPTER, hAccessor, pData, prghRows);
		if (FAILED(hr))
		{
			goto Abort;
		}

		// Get the row data
		//
		hr = pIRowset->GetData(rghRows[0], hAccessor, pData);
        if(FAILED(hr))
        {
			goto Abort;
        }

        // Check the status
        //
        if (DBSTATUS_S_OK != *(DBSTATUS*)(pData+prgBinding[dwPhotoCol].obStatus))
        {
            hr = E_FAIL;
			goto Abort;
        }

		// Insert photo into database through ISequentialStream
		//
		pISequentialStream = (*(ISequentialStream**) (pData + prgBinding[dwPhotoCol].obValue));
		if (pISequentialStream)
		{
			// Insert photo
			//
			hr = SaveEmployeePhoto(pISequentialStream, g_SampleEmployeeData[dwRow].dwEmployeePhoto);
			if(FAILED(hr))
			{
				goto Abort;
			}

			// Release ISequentialStream interface
			//
			hr = pISequentialStream->Release();
			if(FAILED(hr))
			{
				pISequentialStream = NULL;
				goto Abort;
			}

			pISequentialStream = NULL;
		}

        // Release the rowset
		//
		hr = pIRowset->ReleaseRows(1, prghRows, NULL, NULL, NULL);
        if(FAILED(hr))
        {
			goto Abort;
        }

        prghRows[0] = DB_NULL_HROW;
	}

	// Commit the transaction
	//
	if (pITxnLocal)
	{
		pITxnLocal->Commit(FALSE, XACTTC_SYNC, 0);
	}

	goto Exit;

Abort:
    if (DB_NULL_HROW != prghRows[0])
    {
        pIRowset->ReleaseRows(1, prghRows, NULL, NULL, NULL);
    }

	// Abort the transaction
	//
	if (pITxnLocal)
	{
		pITxnLocal->Abort(NULL, FALSE, FALSE);
	}

Exit:
    // Clear Variants
    //
	VariantClear(&rowsetprop[0].vValue);

    // Free allocated DBBinding memory
    //
    if (prgBinding)
    {
        CoTaskMemFree(prgBinding);
        prgBinding = NULL;
    }

    // Free allocated column info memory
    //
    if (pDBColumnInfo)
    {
        CoTaskMemFree(pDBColumnInfo);
        pDBColumnInfo = NULL;
    }
	
	// Free allocated column string values buffer
    //
    if (pStringsBuffer)
    {
        CoTaskMemFree(pStringsBuffer);
        pStringsBuffer = NULL;
    }

    // Free data record buffer
    //
	if (pData)
	{
        CoTaskMemFree(pData);
		pData = NULL;
	}

	// Release interfaces
	//
    if(pISequentialStream)
    {
		pISequentialStream->Release();
    }

	if(pIAccessor)
	{
		pIAccessor->ReleaseAccessor(hAccessor, NULL); 
		pIAccessor->Release();
	}

	if (pIColumnsInfo)
	{
		pIColumnsInfo->Release();
	}

	if (pIRowsetChange)
	{
		pIRowsetChange->Release();
	}

	if (pITxnLocal)
	{
		pITxnLocal->Release();
	}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧洲日韩一区二区三区| 欧美美女bb生活片| 国产精品一二三区| 美女视频免费一区| 亚洲v日本v欧美v久久精品| 洋洋成人永久网站入口| 一区二区在线免费观看| 亚洲一区二区三区四区在线| 午夜日韩在线观看| 午夜视黄欧洲亚洲| 欧美日韩专区在线| 欧美高清hd18日本| 7777女厕盗摄久久久| 日韩一区二区在线看| 欧美成人精品3d动漫h| 久久综合狠狠综合久久综合88| 欧美精品一区二区三| 久久九九99视频| 国产精品色眯眯| 亚洲精品中文字幕在线观看| 亚洲国产成人av好男人在线观看| 午夜免费欧美电影| 老鸭窝一区二区久久精品| 精品一区二区三区免费毛片爱| 国产很黄免费观看久久| av高清不卡在线| 色8久久人人97超碰香蕉987| 欧美日韩国产综合视频在线观看| 欧美一区二区黄| 国产日韩欧美在线一区| 亚洲欧美日韩国产综合在线| 亚洲r级在线视频| 国产真实精品久久二三区| 成人网男人的天堂| 在线精品观看国产| 日韩你懂的在线播放| 国产校园另类小说区| 亚洲精品免费在线| 捆绑调教一区二区三区| www.视频一区| 91精品免费在线观看| 欧美国产精品专区| 亚洲成人免费av| 国产成人精品免费看| 欧美视频精品在线观看| 久久久一区二区三区捆绑**| 一区二区三区日韩| 紧缚捆绑精品一区二区| 99re8在线精品视频免费播放| 91精品黄色片免费大全| 国产精品蜜臀av| 日韩电影在线免费看| 成人性视频免费网站| 欧美另类高清zo欧美| 国产精品久久久一本精品| 日日嗨av一区二区三区四区| 成人免费视频视频在线观看免费| 欧美日韩国产一级二级| 国产日产欧美一区| 天天影视涩香欲综合网 | 韩国精品一区二区| 91视频www| 精品99一区二区| 亚洲精品久久久久久国产精华液| 国产制服丝袜一区| 这里是久久伊人| 亚洲精品高清在线| 国产不卡在线播放| 欧美大片日本大片免费观看| 亚洲欧美日韩精品久久久久| 国产麻豆视频一区二区| 欧美日韩在线精品一区二区三区激情| 久久久久久久久免费| 婷婷丁香激情综合| 色偷偷久久人人79超碰人人澡| 欧美精品一区二| 日日夜夜精品视频免费| 色婷婷综合激情| 国产精品日日摸夜夜摸av| 99精品国产热久久91蜜凸| 日韩欧美在线1卡| 亚洲一区自拍偷拍| 99久久精品国产观看| 久久综合丝袜日本网| 日韩精彩视频在线观看| 在线免费精品视频| 中文字幕制服丝袜成人av| 国产又黄又大久久| 欧美一级国产精品| 视频一区免费在线观看| 欧美在线观看你懂的| 亚洲欧美综合色| 国产91精品一区二区麻豆网站| 欧美v日韩v国产v| 日韩电影在线一区二区三区| 欧美夫妻性生活| 爽爽淫人综合网网站| 欧美亚洲综合在线| 一区二区三区成人| 色综合久久综合| 伊人色综合久久天天| 91免费观看视频| 亚洲欧美色图小说| 99r国产精品| 亚洲私人黄色宅男| 99精品欧美一区二区三区综合在线| 国产欧美一区二区三区网站 | 欧美精品在欧美一区二区少妇| 一区二区三区在线观看网站| 色噜噜狠狠一区二区三区果冻| 成人欧美一区二区三区白人| www.av亚洲| 一区二区三区四区亚洲| 91国内精品野花午夜精品| 亚洲影视在线播放| 欧美猛男gaygay网站| 日韩影视精彩在线| 日韩欧美三级在线| 久久精品99国产国产精| 精品国产3级a| 国产成人午夜精品影院观看视频 | 亚洲精品一卡二卡| 欧美伊人久久久久久午夜久久久久| 性做久久久久久久久| 欧美一区二区免费视频| 国内一区二区视频| 中文字幕久久午夜不卡| 91麻豆高清视频| 一区二区三区在线视频观看| 欧美三级蜜桃2在线观看| 婷婷丁香久久五月婷婷| 精品国产网站在线观看| 国产成人精品亚洲午夜麻豆| 亚洲免费看黄网站| 91精品国产欧美一区二区| 韩国女主播一区二区三区| 欧美国产丝袜视频| 欧美午夜精品久久久久久超碰 | 91精品国产入口在线| 国模无码大尺度一区二区三区 | 99久免费精品视频在线观看| 一区二区三区 在线观看视频| 欧美高清视频www夜色资源网| 九九视频精品免费| 中文字幕亚洲综合久久菠萝蜜| 欧美日韩国产123区| 国产激情一区二区三区桃花岛亚洲| 亚洲欧美在线aaa| 在线成人av影院| 国产成人综合亚洲网站| 亚洲午夜一区二区| 欧美精品一区二区三区在线播放| 欧美女孩性生活视频| 国产成人一区二区精品非洲| 亚洲一本大道在线| 久久婷婷国产综合国色天香 | 亚洲国产精华液网站w| 欧美这里有精品| 国产在线精品一区二区夜色| 亚洲激情欧美激情| 精品久久久久久最新网址| 色综合天天狠狠| 国内精品写真在线观看 | 91精彩视频在线观看| 久久成人精品无人区| 亚洲精品v日韩精品| 久久久三级国产网站| 欧美福利视频导航| 99re视频精品| 国产伦精一区二区三区| 视频一区二区不卡| 亚洲免费资源在线播放| 久久久国产精品午夜一区ai换脸| 欧美精品乱码久久久久久按摩| 成人av电影在线观看| 国模一区二区三区白浆| 日欧美一区二区| 亚洲一级二级三级在线免费观看| 久久一留热品黄| 日韩欧美综合一区| 欧洲av一区二区嗯嗯嗯啊| 盗摄精品av一区二区三区| 蜜桃视频免费观看一区| 亚洲成人av资源| 亚洲免费观看高清完整版在线| 国产精品女同一区二区三区| 精品国产髙清在线看国产毛片 | 一区二区三区欧美久久| 久久久精品影视| 精品裸体舞一区二区三区| 欧美放荡的少妇| 欧美日韩中文另类| 91香蕉国产在线观看软件| 国产 欧美在线| 国产毛片精品一区| 精品一区二区三区蜜桃| 久久精品99久久久| 蜜臀av性久久久久av蜜臀妖精| 日韩电影免费一区| 亚洲一区二区三区四区在线免费观看 |