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

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

?? employees.cpp

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

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

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

	return hr;
}	

////////////////////////////////////////////////////////////////////////////////
// Function: SaveEmployeePhoto()
//
// Description: Save employee photo to database.
//
// Returns: NOERROR if succesfull
//
// Notes:
//
////////////////////////////////////////////////////////////////////////////////
HRESULT Employees::SaveEmployeePhoto(ISequentialStream* pISequentialStream, DWORD dwPhotoID)
{
	HRESULT hr = E_FAIL;
	HRSRC	hrSrc;
	HGLOBAL hPhoto;
	BYTE	*pPhotoData = NULL;
	DWORD	dwSize;
	DWORD	dwWritten;

	// Determine the location of the employee photo resource 
	//
	hrSrc = FindResource(m_hInstance, MAKEINTRESOURCE(dwPhotoID), TEXT("PHOTO")); 
	if (NULL == hrSrc)
	{
        goto Exit;
	}

	// Load the employee photo resource into memory
	//
	hPhoto = LoadResource(m_hInstance, hrSrc);
	if (NULL == hPhoto)
	{
        goto Exit;
	}

	// Lock the resource in memory
	// Get a pointer to the first byte of the resource
	//
	pPhotoData = (BYTE*)LockResource(hPhoto);
	if (NULL == pPhotoData)
	{
        goto Exit;
	}

	// Get the size, in bytes, of the resource
	//
	dwSize = SizeofResource(m_hInstance, hrSrc);
	if (0 == dwSize)
	{
		goto Exit;
	}

	// Write the photo data into the stream object 
	//
	hr = pISequentialStream->Write(pPhotoData, dwSize, &dwWritten);
	if(FAILED(hr) || (dwWritten != dwSize)) 
	{
		goto Exit;
	}

	hr = NOERROR;

Exit:
	// Release memory
	if (hPhoto)
	{
		DeleteObject(hPhoto);
	}

	return hr;
}

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

	IOpenRowset				*pIOpenRowset		= NULL;				// Provider Interface Pointer
	IRowset					*pIRowset			= NULL;				// Provider Interface Pointer
	IColumnsInfo			*pIColumnsInfo		= NULL;				// Provider Interface Pointer
	IAccessor*			    pIAccessor			= NULL;				// Provider Interface Pointer
	HACCESSOR			    hAccessor			= DB_NULL_HACCESSOR;// Accessor handle

	WCHAR*					pwszEmployees[]		=	{				// Info to retrieve employee names
														L"EmployeeID",
														L"LastName", 
														L"FirstName"
													 };

    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;
    }

	// 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 IRowsetIndex interface
	rowsetpropset[0].cProperties	= 1;
	rowsetpropset[0].guidPropertySet= DBPROPSET_ROWSET;
	rowsetpropset[0].rgProperties	= rowsetprop;

	rowsetprop[0].dwPropertyID		= DBPROP_IRowsetIndex;
	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 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.
	//
	dwBindingSize = sizeof(pwszEmployees)/sizeof(pwszEmployees[0]);
	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)
    {
		if (!GetColumnOrdinal(pDBColumnInfo, ulNumCols, pwszEmployees[dwIndex], &dwOrdinal))
		{
			hr = E_FAIL;
			goto Exit;
		}

		prgBinding[dwIndex].iOrdinal	= dwOrdinal;
		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);
		prgBinding[dwIndex].wType		= pDBColumnInfo[dwOrdinal].wType;
		prgBinding[dwIndex].pTypeInfo	= NULL;
		prgBinding[dwIndex].pObject		= NULL;
		prgBinding[dwIndex].pBindExt	= NULL;
		prgBinding[dwIndex].dwMemOwner	= DBMEMOWNER_CLIENTOWNED;
		prgBinding[dwIndex].dwFlags		= 0;
		prgBinding[dwIndex].bPrecision	= pDBColumnInfo[dwOrdinal].bPrecision;
		prgBinding[dwIndex].bScale		= pDBColumnInfo[dwOrdinal].bScale;

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

		// Calculate the offset, and properly align it
		// 
		dwOffset = prgBinding[dwIndex].obValue + prgBinding[dwIndex].cbMaxLen;
		dwOffset = ROUND_UP(dwOffset, COLUMN_ALIGNVAL);
	}

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

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

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

	// Allocate a memory big enough to held employee name
	// LastName + ', ' + FirstName
	//
	pwszName = (WCHAR*)CoTaskMemAlloc(prgBinding[1].cbMaxLen + prgBinding[2].cbMaxLen + 2);
	if (NULL == pwszName)
	{
		hr = E_OUTOFMEMORY;
		goto Exit;
	}

	// Retrive a row
	//
	hr = pIRowset->GetNextRows(DB_NULL_HCHAPTER, 0, 1, &cRowsObtained, &prghRows);
	while (SUCCEEDED(hr) && DB_S_ENDOFROWSET != hr)
	{
		// Set data buffer to zero
		//
		memset(pData, 0, dwOffset);

		// Fetch actual data
		hr = pIRowset->GetData(prghRows[0], hAccessor, pData);
		if (FAILED(hr))
		{
			// Release the rowset.
			//
			pIRowset->ReleaseRows(1, prghRows, NULL, NULL, NULL);
			goto Exit;
		}

		// If return a null value, ignore the contents of the value and length parts of the buffer.
		//
		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[0].obStatus))
		{
			// If return a null value, ignore the contents of the value and length parts of the buffer.
			//
			if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[1].obStatus) && 
				DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[2].obStatus))
			{
				// Combine employee last name and first name
				//
				wcscpy(pwszName, (WCHAR*)(pData+prgBinding[1].obValue));
				wcscat(pwszName, L", ");
				wcscat(pwszName, (WCHAR*)(pData+prgBinding[2].obValue));

				// Add new item into combobox
				//
				dwIndex = SendDlgItemMessage(m_hWndEmployees, IDC_COMBO_NAME, CB_ADDSTRING, 0, (LPARAM)pwszName);
				if (CB_ERR != dwIndex)
				{
					// Set item assocaited data to employee id.
					SendDlgItemMessage(	m_hWndEmployees, 
										IDC_COMBO_NAME, 
										CB_SETITEMDATA, 
										dwIndex, 
										*(LONG*)(pData+prgBinding[0].obValue));
				}
			}
		}

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

	    // Free allocated memory for row handles.
	    //
		if (prghRows)
		{
			CoTaskMemFree(prghRows);
			prghRows = NULL;
		}

		// Fetches next row.
		hr = pIRowset->GetNextRows(DB_NULL_HCHAPTER, 0, 1, &cRowsObtained, &prghRows);
	}

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

    // Free allocated memory for row handles.
    //
	if (prghRows)
	{
        CoTaskMemFree(prghRows);
        prghRows = NULL;
	}

    // 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;
	}

    // Free employee name buffer
    //
	if (pwszName)
	{
		CoTaskMemFree(pwszName);
		pwszName = NULL;
	}

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

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

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

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

	return hr;
}

////////////////////////////////////////////////////////////////////////////////
// Function: LoadEmployeeInfo()
//
// Description: Update employee info based on employee id.
//
// Returns: NOERROR if succesfull
//
// Notes:
//
////////////////////////////////////////////////////////////////////////////////
HRESULT Employees::LoadEmployeeInfo(DWORD dwEmployeeID)
{
	HRESULT				hr					= NOERROR;			// Error code reporting
	DBBINDING			*prgBinding			= NULL;				// Binding used to create accessor
	HROW				rghRows[1];								// 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				dwOffset			= 0;
	DWORD				dwOrdinal			= 0;
	ULONG				ulNumCols;

	IOpenRowset			*pIOpenRowset		= NULL;				// Provider Interface Pointer
	IRowset				*pIRowset			= NULL;				// Provider Interface Pointer

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色婷婷精品久久二区二区蜜臂av| 国产一区二区不卡在线| 欧美电影免费观看高清完整版在线观看| 国产91精品精华液一区二区三区| 日韩不卡一二三区| 美女视频一区二区| 玖玖九九国产精品| 极品美女销魂一区二区三区| 久久99精品国产91久久来源| 老司机精品视频一区二区三区| 午夜激情一区二区三区| 亚洲444eee在线观看| 手机精品视频在线观看| 日本三级亚洲精品| 国内久久精品视频| 国产精品1024| 99精品国产99久久久久久白柏| 青青草国产精品亚洲专区无| 蜜臀va亚洲va欧美va天堂| 亚洲成人一区二区在线观看| 麻豆一区二区三区| 国产精品综合网| 蜜臀精品久久久久久蜜臀| 韩日欧美一区二区三区| av成人动漫在线观看| 欧美在线短视频| 精品久久一二三区| 中文乱码免费一区二区| 亚洲美女免费视频| 免费高清不卡av| 国产成人免费视频网站 | 久久久蜜桃精品| 精品国产一区二区三区av性色| 欧美一区二区视频观看视频| 久久免费美女视频| 一区二区三区在线观看网站| 玉米视频成人免费看| 奇米影视一区二区三区| 成人免费毛片片v| 6080国产精品一区二区| 日韩欧美电影一区| 日韩一级欧美一级| 日韩毛片精品高清免费| 久久不见久久见免费视频7| 91在线视频在线| 精品国精品自拍自在线| 亚洲第一成年网| 成人动漫一区二区| 2014亚洲片线观看视频免费| 亚洲午夜久久久久| 99久久精品国产精品久久| 精品精品国产高清一毛片一天堂| 亚洲视频1区2区| 国产伦精品一区二区三区免费| 欧美日韩小视频| 亚洲精品欧美激情| 粉嫩在线一区二区三区视频| 日韩无一区二区| 午夜视频一区二区三区| 色婷婷国产精品久久包臀 | 国产美女久久久久| 国内精品不卡在线| 国产精品久久久爽爽爽麻豆色哟哟 | 丁香五精品蜜臀久久久久99网站| 日本欧美久久久久免费播放网| 午夜精彩视频在线观看不卡| 亚洲成a人片综合在线| 国产精品不卡在线| 久久久精品黄色| 亚洲欧美日韩国产综合| 一区二区在线电影| 亚洲人成7777| 日韩在线a电影| 亚洲成人综合网站| 日本人妖一区二区| 精品一区二区在线播放| 国产麻豆视频一区二区| 国产一区二区不卡在线| 成人性视频免费网站| 色哟哟欧美精品| 欧美伊人久久大香线蕉综合69| 91精品国产综合久久香蕉麻豆| 精品国一区二区三区| 亚洲国产成人自拍| 亚洲成人综合在线| 国产成人精品网址| 欧美色综合网站| 久久综合精品国产一区二区三区| 337p日本欧洲亚洲大胆色噜噜| 日本一区二区三区四区在线视频| 中文字幕乱码日本亚洲一区二区 | 99久久久国产精品| 欧美精品欧美精品系列| 久久女同互慰一区二区三区| 亚洲一区免费在线观看| 国产精品一区二区在线观看不卡| 99v久久综合狠狠综合久久| 日韩精品影音先锋| 亚洲一区二区欧美日韩| 国产精品一区二区免费不卡| 欧美挠脚心视频网站| 国产精品久久久爽爽爽麻豆色哟哟| 国产成人免费在线观看| 国产麻豆精品视频| 日韩视频在线永久播放| 国产清纯白嫩初高生在线观看91 | 国产女主播视频一区二区| 亚瑟在线精品视频| 日本道色综合久久| 久久亚区不卡日本| 麻豆精品新av中文字幕| 精品视频一区 二区 三区| 亚洲乱码国产乱码精品精的特点 | 精品嫩草影院久久| ●精品国产综合乱码久久久久| 久久精品国产99国产| 日韩三级视频在线看| 视频在线在亚洲| 在线免费不卡视频| 国产精品久久久久久户外露出| 国产乱码一区二区三区| 日韩午夜精品电影| 亚洲一区二区三区四区不卡| 欧美一区二区在线不卡| 五月天亚洲婷婷| 91精品欧美久久久久久动漫| 日韩精品91亚洲二区在线观看| 在线不卡中文字幕播放| 日日噜噜夜夜狠狠视频欧美人| 欧美日韩激情一区| 色综合中文字幕国产 | 国产成人亚洲综合a∨婷婷| 久久久一区二区| 99精品黄色片免费大全| 国产精品欧美一区二区三区| 色综合久久中文综合久久牛| 亚洲高清视频中文字幕| 欧美精品777| 午夜精品国产更新| 久久综合久久综合久久综合| 理论电影国产精品| 欧美激情在线看| 91激情在线视频| 美腿丝袜在线亚洲一区| 国产精品国产精品国产专区不蜜| 色诱视频网站一区| 久久激情五月婷婷| 伊人色综合久久天天人手人婷| 欧美精品xxxxbbbb| 成人精品视频一区二区三区| 偷拍一区二区三区四区| 欧美精品一区二区三区一线天视频 | 国产精品国产三级国产普通话蜜臀| 在线精品视频一区二区三四| 蜜桃一区二区三区四区| 国产亚洲精品7777| 欧美伊人久久久久久久久影院 | 国产欧美一区二区三区网站| 在线观看日韩电影| 成人午夜视频免费看| 日韩1区2区3区| 一区二区欧美在线观看| 国产精品久久精品日日| 欧美一级艳片视频免费观看| 91久久精品网| 成av人片一区二区| 国产风韵犹存在线视精品| 午夜精品爽啪视频| 亚洲国产色一区| 亚洲免费av高清| 亚洲欧美日韩在线| 国产精品传媒在线| 国产精品女主播av| 久久亚洲精精品中文字幕早川悠里 | 欧美精品一区男女天堂| 91精品国产综合久久精品性色| 欧美性做爰猛烈叫床潮| 91在线视频播放| 91丨porny丨在线| 91在线精品一区二区三区| 成人手机在线视频| 成人h动漫精品一区二区| 成人午夜看片网址| 国产麻豆日韩欧美久久| 国产精品 日产精品 欧美精品| 国产一区在线不卡| 麻豆精品一二三| 日本aⅴ亚洲精品中文乱码| 天堂蜜桃91精品| 免费观看在线综合| 国产在线日韩欧美| 99久久精品国产毛片| 一本色道久久综合亚洲aⅴ蜜桃 | 国产日韩欧美精品一区| 亚洲欧洲性图库| 亚洲aaa精品| 韩国三级电影一区二区| www.亚洲色图.com| 欧美性感一区二区三区| 欧美日韩视频一区二区|