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

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

?? employees.cpp

?? EVC下OLEDB方法編寫的數據庫源代碼
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
//
// Description: Show employee photo.
//
// Notes: This sample only display 24 bit bitmap
//
////////////////////////////////////////////////////////////////////////////////
void Employees::ShowEmployeePhoto()
{
	HDC					hdcMem;
	HDC					hDC;

	// If m_hBitmap is NULL, 
	// clear the photo area with a gray rectangle
	//
	if (NULL == m_hBitmap)
	{
		HBRUSH				hBrush;
		RECT				rect;

		SetRect(&rect, PHOTO_X, PHOTO_Y, PHOTO_X + PHOTO_WIDTH, PHOTO_Y + PHOTO_HEIGHT);

		hDC = GetDC(m_hWndEmployees);
		hBrush = CreateSolidBrush(RGB(192, 192, 192));
		FillRect(hDC, &rect, hBrush);

		DeleteObject(hBrush);
		ReleaseDC(m_hWndEmployees, hDC);

		return;
	}

	// Retrieve the device context handle
	//
	hDC = GetDC(m_hWndEmployees);

	// Creates a memory device context, select bitmap handle
	//
	hdcMem = CreateCompatibleDC(hDC);
	SelectObject(hdcMem, m_hBitmap);

	// Display bitmap,
	//
	BitBlt(	hDC, 
				PHOTO_X, 
				PHOTO_Y, 
				PHOTO_WIDTH,
				PHOTO_HEIGHT, 
				hdcMem, 
				0, 
				0,  
				SRCCOPY); 

	// Delete bitmap object, release the device contexts, 
	//
	DeleteDC(hdcMem);
	ReleaseDC(m_hWndEmployees, hDC);
}


////////////////////////////////////////////////////////////////////////////////
// Function: ClearEmployeeInfo()
//
// Description: clear employee info displayed on the window.
//
// Returns:
//
// Notes:
//
////////////////////////////////////////////////////////////////////////////////
void Employees::ClearEmployeeInfo()
{
	SetDlgItemText(m_hWndEmployees, IDC_EDIT_EMPLOYEE_ID, L"");
	SetDlgItemText(m_hWndEmployees, IDC_EDIT_ADDRESS,     L"");
	SetDlgItemText(m_hWndEmployees, IDC_EDIT_CITY,        L"");
	SetDlgItemText(m_hWndEmployees, IDC_EDIT_REGION,      L"");
	SetDlgItemText(m_hWndEmployees, IDC_EDIT_POSTAL_CODE, L"");
	SetDlgItemText(m_hWndEmployees, IDC_EDIT_COUNTRY,     L"");
	SetDlgItemText(m_hWndEmployees, IDC_EDIT_HOME_PHONE,  L"");

	LoadEmployeePhoto(NULL);
}

////////////////////////////////////////////////////////////////////////////////
// Function: SaveEmployeeInfo()
//
// Description: Save employee info to database.
//
// Returns: NOERROR if succesfull
//
// Notes:
//
////////////////////////////////////////////////////////////////////////////////
HRESULT Employees::SaveEmployeeInfo(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[2];							// Used when opening integrated index
   	ULONG				cRowsObtained		= 0;				// Number of rows obtained from the rowset object
	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
    IRowsetChange		*pIRowsetChange		= NULL;
	IRowsetIndex		*pIRowsetIndex		= NULL;				// Provider Interface Pointer
	IAccessor			*pIAccessor			= NULL;				// Provider Interface Pointer
	IColumnsInfo		*pIColumnsInfo		= NULL;				// Provider Interface Pointer
	HACCESSOR			hAccessor			= DB_NULL_HACCESSOR;// Accessor handle

	WCHAR*				pwszEmployees[]		=	{				// Employee info column names
													L"EmployeeID",
													L"Address",
													L"City",
													L"Region",
													L"PostalCode",
													L"Country",
													L"HomePhone"
												};
	
	VariantInit(&rowsetprop[0].vValue);
	VariantInit(&rowsetprop[1].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 IRowsetChange interface
	// 
	rowsetpropset[0].cProperties	= 2;
	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;

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

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

    // Get IRowset interface
	//
	hr = pIRowsetIndex->QueryInterface(IID_IRowset, (void**) &pIRowset);
	if(FAILED(hr))
	{
		goto Exit;
	}

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

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

    // Set data buffer for seek operation
    //
	*(ULONG*)(pData+prgBinding[0].obLength)		= 4;
	*(DBSTATUS*)(pData+prgBinding[0].obStatus)	= DBSTATUS_S_OK;
	*(int*)(pData+prgBinding[0].obValue)		= dwEmployeeID;

	// Position at a key value within the current range 
	//
	hr = pIRowsetIndex->Seek(hAccessor, 1, pData, DBSEEK_FIRSTEQ);
	if(FAILED(hr))
	{
		goto Exit;	
	}

    // Retrieve a row handle for the row resulting from the seek
    //
    hr = pIRowset->GetNextRows(DB_NULL_HCHAPTER, 0, 1, &cRowsObtained, &prghRows);
	if(FAILED(hr))
	{
		goto Exit;	
	}

	if (DB_S_ENDOFROWSET != hr)
	{
		GetDlgItemText(m_hWndEmployees, IDC_EDIT_ADDRESS,	  (WCHAR*)(pData+prgBinding[1].obValue), prgBinding[1].cbMaxLen);
		GetDlgItemText(m_hWndEmployees, IDC_EDIT_CITY,		  (WCHAR*)(pData+prgBinding[2].obValue), prgBinding[2].cbMaxLen);
		GetDlgItemText(m_hWndEmployees, IDC_EDIT_REGION,	  (WCHAR*)(pData+prgBinding[3].obValue), prgBinding[3].cbMaxLen);
		GetDlgItemText(m_hWndEmployees, IDC_EDIT_POSTAL_CODE, (WCHAR*)(pData+prgBinding[4].obValue), prgBinding[4].cbMaxLen);
		GetDlgItemText(m_hWndEmployees, IDC_EDIT_COUNTRY,	  (WCHAR*)(pData+prgBinding[5].obValue), prgBinding[5].cbMaxLen);
		GetDlgItemText(m_hWndEmployees, IDC_EDIT_HOME_PHONE,  (WCHAR*)(pData+prgBinding[6].obValue), prgBinding[6].cbMaxLen);

		for (dwIndex = 1; dwIndex <= 6; ++dwIndex)
		{
			*(ULONG*)(pData+prgBinding[dwIndex].obLength)	 = wcslen((WCHAR*)(pData+prgBinding[dwIndex].obValue))*sizeof(WCHAR);
			*(DBSTATUS*)(pData+prgBinding[dwIndex].obStatus) = DBSTATUS_S_OK;
		}

		// Set data to database
		//
		hr = pIRowsetChange->SetData(prghRows[0], hAccessor, pData);
	}

	// Release the rowset.
	//
	pIRowset->ReleaseRows(1, prghRows, NULL, NULL, NULL);

Exit:
    // Clear Variants
    //
	VariantClear(&rowsetprop[0].vValue);
	VariantClear(&rowsetprop[1].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;
	}

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

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

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

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

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

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

	return hr;
}

////////////////////////////////////////////////////////////////////////////////
// Function: GetColumnOrdinal()
//
// Description: Returns column ordinal for column name.
//
// Parameters
//		pDBColumnInfo	- a pointer to Database column info
//		dwNumCols		- number of columns
//		pwszColName		- column name
//		pOrdinal		- column ordinal
//
// Returns: TRUE if succesfull
//
////////////////////////////////////////////////////////////////////////////////
BOOL Employees::GetColumnOrdinal(DBCOLUMNINFO* pDBColumnInfo, DWORD dwNumCols, WCHAR* pwszColName, DWORD* pOrdinal)
{
	for(DWORD dwCol = 0; dwCol< dwNumCols; ++dwCol)
	{
		if(NULL != pDBColumnInfo[dwCol].pwszName)
		{
			if(0 == _wcsicmp(pDBColumnInfo[dwCol].pwszName, pwszColName))
			{
				*pOrdinal = pDBColumnInfo[dwCol].iOrdinal;
				return TRUE;
			}
		}
	}

	return FALSE;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人成网站在线| 国产亚洲短视频| 欧美xfplay| 国产精品久久久久久久久免费樱桃 | 日本道在线观看一区二区| 国产不卡一区视频| 欧美福利一区二区| 国产精品色哟哟| 偷拍一区二区三区| 不卡的av在线| 色88888久久久久久影院野外| 欧美日韩午夜影院| 久久精品视频一区二区三区| 亚洲成人av中文| 国产精品99久久久| 欧美日韩成人综合| 国产精品久久久久久久久快鸭 | 久久综合一区二区| 亚洲精品国产成人久久av盗摄| 日韩在线一区二区三区| 99精品视频在线观看| 欧美精品一区二区三区蜜臀| 亚洲国产精品久久一线不卡| 国产超碰在线一区| 精品乱码亚洲一区二区不卡| 一区二区在线观看免费| 国产精品一区二区三区乱码| 欧美日韩免费不卡视频一区二区三区| 国产日韩欧美精品电影三级在线| 日韩二区三区四区| 欧美影院一区二区| 国产精品久久久久久久久免费樱桃| 精品在线一区二区三区| 欧美午夜精品一区二区蜜桃| 国产精品久久福利| 成人激情av网| 精品三级在线看| 老司机精品视频线观看86 | 婷婷夜色潮精品综合在线| 国内外精品视频| 日韩欧美激情四射| 六月丁香婷婷色狠狠久久| 91精品在线观看入口| 亚洲成人av一区二区三区| 91色乱码一区二区三区| 国产精品成人免费在线| 大桥未久av一区二区三区中文| 久久久99精品久久| 国产传媒日韩欧美成人| 国产欧美一区在线| 国产精品一级二级三级| 国产亚洲va综合人人澡精品| 丰满亚洲少妇av| 中文字幕乱码一区二区免费| 成人免费视频一区| 最新欧美精品一区二区三区| 91在线播放网址| 亚洲高清免费视频| 在线电影院国产精品| 久久av中文字幕片| 欧美精品一区二区三区高清aⅴ| 狠狠色综合播放一区二区| 精品国产乱码久久| 国产精品一区二区无线| 国产欧美精品一区二区色综合| 成人av网站免费| 中文字幕亚洲成人| 欧美影院一区二区| 久久99精品久久久久久| 久久久久久亚洲综合| 成人午夜在线播放| 亚洲综合丝袜美腿| 日韩亚洲欧美综合| 懂色av一区二区在线播放| 中文字幕一区二区三区不卡 | 免费看黄色91| 久久久久久久久蜜桃| 91同城在线观看| 奇米色777欧美一区二区| 久久伊人中文字幕| 99久久99久久精品国产片果冻| 洋洋av久久久久久久一区| 欧美一区二区播放| 97精品国产露脸对白| 日韩电影免费在线看| 国产精品无码永久免费888| 91麻豆免费看| 国产中文字幕一区| 亚洲国产精品二十页| 91在线视频18| 天天综合色天天综合| 久久久久国产精品免费免费搜索| 91在线小视频| 精品一区二区在线免费观看| 亚洲另类中文字| 日韩免费成人网| 在线精品国精品国产尤物884a | 欧美一级xxx| 国产成人免费高清| 亚洲视频一区二区免费在线观看| 欧美一级片在线看| 日本高清不卡在线观看| 国产美女一区二区三区| 亚洲成人免费在线观看| 亚洲欧洲另类国产综合| 精品伦理精品一区| 欧美日本不卡视频| 一本在线高清不卡dvd| 激情av综合网| 青青草精品视频| 亚洲福利一区二区| 国产精品福利一区| 亚洲精品在线电影| 欧美高清激情brazzers| 91小视频免费观看| 粉嫩av一区二区三区在线播放 | 成人av小说网| 日韩精品久久理论片| 亚洲情趣在线观看| 国产欧美日韩亚州综合| 日韩一区国产二区欧美三区| 欧美亚一区二区| 日本精品一区二区三区高清| 成人av在线观| www.99精品| 99v久久综合狠狠综合久久| 国产91富婆露脸刺激对白| 国产传媒一区在线| 国产精品1区2区| 国产精品中文欧美| 国产高清成人在线| 国产尤物一区二区| 国产成人自拍在线| 国产mv日韩mv欧美| 成人免费高清在线| 99精品视频在线免费观看| 丁香婷婷综合网| 国产精品一区2区| 福利电影一区二区| 99国产精品久久久久| 一本大道av伊人久久综合| 在线亚洲免费视频| 欧美日韩国产小视频在线观看| 欧美色图免费看| 欧美一级欧美三级在线观看| 日韩欧美亚洲国产另类| 26uuu亚洲| 国产精品视频看| 亚洲最大成人综合| 裸体歌舞表演一区二区| 国产福利不卡视频| av电影在线观看完整版一区二区| 91麻豆免费看| 91精品国产全国免费观看| 亚洲精品在线观看视频| 日韩毛片在线免费观看| 天天色天天操综合| 精品一区二区三区影院在线午夜| 国产成人福利片| 欧美性猛交xxxxxxxx| 精品国产三级a在线观看| 国产精品午夜免费| 中文字幕亚洲一区二区av在线 | 秋霞影院一区二区| 国产成人欧美日韩在线电影| 精品视频资源站| 日韩免费福利电影在线观看| 国产精品久线在线观看| 三级影片在线观看欧美日韩一区二区| 精品一二三四区| 91碰在线视频| 精品国产污污免费网站入口| 亚洲人成影院在线观看| 极品美女销魂一区二区三区免费 | 免费观看91视频大全| 丁香天五香天堂综合| 91婷婷韩国欧美一区二区| 欧美精三区欧美精三区| 亚洲国产精品二十页| 日本aⅴ亚洲精品中文乱码| 99在线热播精品免费| 国产精品久久久久久久久免费樱桃| 亚洲成人综合网站| 91在线你懂得| 26uuu精品一区二区 | 在线不卡a资源高清| 国产精品天美传媒| 热久久国产精品| 波多野结衣中文一区| 在线观看视频一区| 国产精品三级视频| 久久电影网站中文字幕| 欧美色精品在线视频| 色综合视频在线观看| 久久久影视传媒| 成人一区二区视频| 国产精品久久久久影院老司| 欧美日韩在线精品一区二区三区激情| 国产精品国产a级| 99精品欧美一区二区三区小说|