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

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

?? employees.cpp

?? EVC下OLEDB方法編寫的數(shù)據(jù)庫(kù)源代碼
?? CPP
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
	IRowsetIndex		*pIRowsetIndex		= NULL;				// Provider Interface Pointer
	IAccessor			*pIAccessor			= NULL;				// Provider Interface Pointer
	ILockBytes			*pILockBytes		= 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",
													L"Photo"	
												};
	
	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 IRowsetChange 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_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;
	}

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

		// Prepare structures to create the accessor
		//
		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].pBindExt	= NULL;
		prgBinding[dwIndex].dwMemOwner	= DBMEMOWNER_CLIENTOWNED;
		prgBinding[dwIndex].dwFlags		= 0;
		prgBinding[dwIndex].bPrecision	= pDBColumnInfo[dwOrdinal].bPrecision;
		prgBinding[dwIndex].bScale		= pDBColumnInfo[dwOrdinal].bScale;

		switch(pDBColumnInfo[dwOrdinal].wType)
		{
		case DBTYPE_BYTES:		// Column "Photo" binding (BLOB) 
			// Set up the DBOBJECT structure.
			//
			dbObject.dwFlags = STGM_READ;
			dbObject.iid	 = IID_ILockBytes;

			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[dwOrdinal].wType;
			prgBinding[dwIndex].cbMaxLen	= sizeof(WCHAR)*(pDBColumnInfo[dwOrdinal].ulColumnSize + 1);	// Extra buffer for null terminator 
			break;

		default:
			prgBinding[dwIndex].pObject		= NULL;
			prgBinding[dwIndex].wType		= pDBColumnInfo[dwOrdinal].wType;
			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)
	{
		// Fetch actual data
		//
		hr = pIRowset->GetData(prghRows[0], hAccessor, pData);
		if (FAILED(hr))
		{
			goto Exit;
		}

		// Clear employee info on the dialog
		//
		ClearEmployeeInfo();

		// Update dialog
		// If return a null value or status is not OK, ignore the contents of the value and length parts of the buffer.
		//
    	if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[0].obStatus) && 
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[0].obStatus))
	    {
		    SetDlgItemInt(m_hWndEmployees,  IDC_EDIT_EMPLOYEE_ID, *(LONG*)(pData+prgBinding[0].obValue), 0);
        }

		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[1].obStatus) &&
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[1].obStatus))
		{
			SetDlgItemText(m_hWndEmployees, IDC_EDIT_ADDRESS, (WCHAR*)(pData+prgBinding[1].obValue));
		}

		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[2].obStatus) &&
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[2].obStatus))
		{
			SetDlgItemText(m_hWndEmployees, IDC_EDIT_CITY, (WCHAR*)(pData+prgBinding[2].obValue));
		}

		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[3].obStatus) &&
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[3].obStatus))
		{
			SetDlgItemText(m_hWndEmployees, IDC_EDIT_REGION, (WCHAR*)(pData+prgBinding[3].obValue));
		}

		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[4].obStatus) &&
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[4].obStatus))
		{
			SetDlgItemText(m_hWndEmployees, IDC_EDIT_POSTAL_CODE, (WCHAR*)(pData+prgBinding[4].obValue));
		}

		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[5].obStatus) &&
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[5].obStatus))
		{
			SetDlgItemText(m_hWndEmployees, IDC_EDIT_COUNTRY, (WCHAR*)(pData+prgBinding[5].obValue));
		}

		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[6].obStatus) &&
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[6].obStatus))
		{
			SetDlgItemText(m_hWndEmployees, IDC_EDIT_HOME_PHONE, (WCHAR*)(pData+prgBinding[6].obValue));
		}

		// Update employee photo
		// 
		if (DBSTATUS_S_ISNULL != *(DBSTATUS *)(pData+prgBinding[7].obStatus) &&
            DBSTATUS_S_OK == *(DBSTATUS *)(pData+prgBinding[7].obStatus))
        {
    		pILockBytes = (*(ILockBytes**) (pData + prgBinding[7].obValue));
	    	LoadEmployeePhoto(pILockBytes);
        }
	}

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

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

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

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

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

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

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

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

	return hr;
}

////////////////////////////////////////////////////////////////////////////////
// Function: LoadEmployeePhoto()
//
// Description: Load employee photo from database.
//
// Returns: NOERROR if succesfull
//
// Notes: This sample only display 24 bit bitmap
//
////////////////////////////////////////////////////////////////////////////////
HRESULT Employees::LoadEmployeePhoto(ILockBytes* pILockBytes)
{
	HRESULT				hr = NOERROR;
	ULONG				ulRead;
	ULARGE_INTEGER		ulStart;
	BITMAPFILEHEADER	bmpFileHeader;
	BITMAPINFO			bmpInfo;
	BYTE				*pPhotoBits;
	HDC					hDC;

	if (m_hBitmap)
	{
		// Delete bitmap object, release the device contexts, 
		//
		DeleteObject(m_hBitmap);
		m_hBitmap = NULL;
	}

	// Validate ILockBytes interface 
	//
	if (NULL == pILockBytes)
	{
		return hr;
	}

	// Read Bitmap file header
	//
	ulRead = 0;
	ulStart.QuadPart = 0;
	hr = pILockBytes->ReadAt(ulStart, &bmpFileHeader, sizeof(BITMAPFILEHEADER), &ulRead);
	if(FAILED(hr) || sizeof(BITMAPFILEHEADER) != ulRead) 
	{
		return hr;
	}

	// Read Bitmap info header
	//
	ulStart.QuadPart += ulRead;
	ulRead = 0;
	hr = pILockBytes->ReadAt(ulStart, &bmpInfo, sizeof(BITMAPINFOHEADER), &ulRead);
	if(FAILED(hr) || sizeof(BITMAPINFOHEADER) != ulRead) 
	{
		return hr;
	}

	// THIS SAMPLE ONLY SUPPORT 24 BIT BITMAP
	//
	if (24 != bmpInfo.bmiHeader.biBitCount)
	{
		return hr;
	}

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

	// Creates a device-independent bitmap (DIB) with bitmap info
	//
	m_hBitmap = CreateDIBSection(	hDC,
								&bmpInfo, 
								DIB_RGB_COLORS, 
								(void **)&pPhotoBits, 
								NULL, 
								0);

	// Read bitmap bits
	//
	ulStart.QuadPart += ulRead;
	ulRead = 0;
	hr = pILockBytes->ReadAt(ulStart, pPhotoBits, bmpInfo.bmiHeader.biSizeImage, &ulRead);
	if(FAILED(hr) || bmpInfo.bmiHeader.biSizeImage != ulRead) 
	{
		// Delete bitmap object, release the device contexts, 
		//
		DeleteObject(m_hBitmap);
		m_hBitmap = NULL;
	}

	ReleaseDC(m_hWndEmployees, hDC);

	return hr;
}

////////////////////////////////////////////////////////////////////////////////
// Function: ShowEmployeePhoto()

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久看| 国产精品一区二区91| 亚洲综合激情网| 夜色激情一区二区| 亚洲一区欧美一区| 天天av天天翘天天综合网色鬼国产| 一区二区三区在线观看视频| 亚洲综合小说图片| 天天操天天色综合| 精品在线播放免费| 激情文学综合网| 国产91精品入口| 不卡一区在线观看| 欧美午夜电影一区| 日韩亚洲欧美综合| 国产视频不卡一区| 日韩美女啊v在线免费观看| 一区二区三区精品在线| 污片在线观看一区二区| 久久91精品国产91久久小草| 国产福利视频一区二区三区| 成人福利视频在线看| 日本高清无吗v一区| 欧美色电影在线| 精品日韩在线一区| 国产精品久久久爽爽爽麻豆色哟哟 | 成人蜜臀av电影| av电影一区二区| 欧美日韩精品久久久| 日韩三级伦理片妻子的秘密按摩| 久久精品亚洲麻豆av一区二区| 一区在线观看免费| 性做久久久久久免费观看| 久久国产福利国产秒拍| 丁香天五香天堂综合| 一本高清dvd不卡在线观看| 911精品产国品一二三产区| 337p粉嫩大胆噜噜噜噜噜91av| 国产精品色噜噜| 亚洲成av人片www| 激情久久五月天| 色综合色综合色综合色综合色综合 | 色av综合在线| 日韩欧美专区在线| 18成人在线视频| 免费av网站大全久久| 成人免费毛片a| 欧美日韩精品综合在线| 久久精品在线观看| 亚洲成人av中文| 成人午夜激情视频| 日韩午夜激情电影| 一区二区三区四区不卡在线| 久久精品国产精品亚洲精品| 91丨porny丨最新| 精品免费国产一区二区三区四区| 亚洲特级片在线| 激情欧美一区二区| 欧美蜜桃一区二区三区| 国产精品美女久久久久久久| 蜜臀久久99精品久久久久久9| 99在线视频精品| 欧美r级在线观看| 亚洲成av人片一区二区| 成人h动漫精品| 欧美v国产在线一区二区三区| 一区二区三区日韩精品视频| 国产精品一区二区x88av| 欧美一级专区免费大片| 一区二区三区日韩欧美| eeuss国产一区二区三区| 精品日韩成人av| 图片区日韩欧美亚洲| 日本韩国欧美三级| 中文字幕一区三区| 国产宾馆实践打屁股91| 精品国产a毛片| 日韩不卡一区二区三区| 色婷婷亚洲精品| 欧美国产日韩在线观看| 激情综合五月婷婷| 欧美一卡二卡三卡四卡| 一区二区三区四区不卡在线| 99精品在线观看视频| 欧美国产精品中文字幕| 久久99精品国产麻豆不卡| 884aa四虎影成人精品一区| 亚洲综合清纯丝袜自拍| 99久久精品国产麻豆演员表| 久久综合色8888| 精品一区二区影视| 欧美一区二区三区视频免费| 亚洲在线观看免费视频| 一本大道久久a久久综合| 综合在线观看色| www.成人网.com| 久久久国产午夜精品| 九色综合狠狠综合久久| 欧美一级欧美三级在线观看| 亚洲成人免费在线观看| 欧美日韩国产成人在线91| 亚洲影院久久精品| 欧美在线免费观看视频| 亚洲精品中文字幕在线观看| 色香蕉成人二区免费| 成人欧美一区二区三区白人 | 国产激情91久久精品导航 | 亚洲成人精品一区| 色综合久久久久网| 亚洲人成小说网站色在线| 91丨porny丨国产入口| 亚洲欧美成aⅴ人在线观看| 成人app软件下载大全免费| 国产精品毛片久久久久久久| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 国产精品资源网| 中文字幕欧美激情一区| 97se狠狠狠综合亚洲狠狠| 日本一区二区三区四区 | 欧美精品乱码久久久久久| 午夜视频在线观看一区二区三区| 91精品国产综合久久婷婷香蕉| 六月婷婷色综合| 国产欧美精品在线观看| 91香蕉视频污| 亚洲国产中文字幕| 日韩视频一区在线观看| 国产99久久久精品| 一区二区三区高清| 日韩视频中午一区| 成人污污视频在线观看| 一区二区三区不卡在线观看| 欧美精品成人一区二区三区四区| 久久精品av麻豆的观看方式| 中文字幕乱码久久午夜不卡| 欧美亚洲免费在线一区| 久久精品国产精品亚洲综合| 国产精品美女久久久久久久| 精品视频一区 二区 三区| 久久aⅴ国产欧美74aaa| 国产精品进线69影院| 欧美高清视频在线高清观看mv色露露十八 | 久久66热偷产精品| 亚洲人成小说网站色在线 | 国产精品美女久久久久aⅴ国产馆| 色婷婷av一区二区三区之一色屋| 奇米777欧美一区二区| 中文字幕在线视频一区| 欧美一区二区久久| 不卡高清视频专区| 热久久国产精品| 国产精品九色蝌蚪自拍| 7777精品久久久大香线蕉| 成人做爰69片免费看网站| 亚洲成年人影院| 亚洲国产精品成人综合 | 国产精品国产a级| 日韩一区二区精品在线观看| eeuss鲁片一区二区三区| 男女激情视频一区| 亚洲理论在线观看| 久久综合成人精品亚洲另类欧美| 在线看国产日韩| 国产成人精品影视| 丝袜美腿亚洲综合| 亚洲摸摸操操av| 国产日韩一级二级三级| 日韩一卡二卡三卡国产欧美| 99久久99久久久精品齐齐| 国内外成人在线| 亚洲a一区二区| 亚洲欧美在线观看| 久久久久久久网| 日韩一级在线观看| 欧美三级日韩在线| av日韩在线网站| 国产成人av一区二区三区在线| 秋霞电影一区二区| 亚洲第一精品在线| 亚洲精品菠萝久久久久久久| 国产午夜精品久久久久久久| 日韩欧美电影一区| 欧美日韩黄色一区二区| 91丨porny丨最新| 成人激情av网| 国产成人在线视频播放| 成人一区二区视频| 国产精品羞羞答答xxdd| 久久99久久久久久久久久久| 天天操天天干天天综合网| 亚洲国产视频网站| 亚洲蜜臀av乱码久久精品蜜桃| 国产精品毛片大码女人| 欧美国产日韩a欧美在线观看| 久久影院午夜片一区| 欧美va亚洲va在线观看蝴蝶网| 在线成人av影院| 在线不卡中文字幕| 制服丝袜亚洲色图| 欧美日韩精品一区二区|