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

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

?? adodb.cpp

?? VC++ 6.0開發。之中打印部分可能對您有值得參考的地方。其他的部分還不是很完善
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// DB.cpp : 實現文件
//

#include "stdafx.h"
#include "afx.h"
#include "ADODB.h"


// CDB
IMPLEMENT_DYNCREATE(CADOConnection, CObject)
CADOConnection::CADOConnection()
{    
	::CoInitialize(NULL);
   HRESULT hr;
   try
   {
     hr=this->m_pConnection.CreateInstance("ADODB.Connection");
     if(SUCCEEDED(hr))
     {
		return;
	 }
   }
   catch(_com_error e)///捕捉異常
   {
        CString errormessage;
        errormessage.Format("連接數據庫失敗!\r\n錯誤信息:%s",e.ErrorMessage());
        AfxMessageBox(errormessage);///顯示錯誤信息
    } 
}

CADOConnection::~CADOConnection()
{
	//if (this->m_pConnection->State  
	
	if (this->IsOpen()) 
	{
	  this->m_pConnection->Close();
	  //this->m_pConnection->Release();  
	  this->m_pConnection=NULL; 
	}
	
	::CoUninitialize();
}

bool CADOConnection::ConDB(CString DbName,CString Password,int DBType)
{
  //HRESULT hr;
  CString constr;
  //獲取連接字符串 
  DbName.TrimRight();
  ASSERT(DbName!=""); 
  if (DBType==0) 
  {
     constr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+DbName+";Persist Security Info=False;";
     Password.TrimRight();
	 if(Password!="")
	 {
	  constr=constr+"Jet OLEDB:Database Password="+Password+";";
	 }
  }
  else
  {
  
  }
  return this->Open(constr);

}


bool CADOConnection::Open(LPCTSTR lpstrConnection)
{
	HRESULT hr = S_OK;

	if(IsOpen())
		Close();

	if(strcmp(lpstrConnection, _T("")) != 0)
		m_strConnection = lpstrConnection;

	ASSERT(!m_strConnection.IsEmpty());

	try
	{
		hr = m_pConnection->Open(_bstr_t(m_strConnection), "", "", NULL);
		return hr == S_OK;
	}
	catch(_com_error &e)
	{
		CString errormessage;
        errormessage.Format("連接數據庫失敗!\r\n錯誤信息:%s",e.ErrorMessage());
        AfxMessageBox(errormessage);///顯示錯誤信息
	}
	return false;
}

bool CADOConnection::Execute(LPCTSTR lpstrExec)
{
	ASSERT(m_pConnection != NULL);
	ASSERT(strcmp(lpstrExec, _T("")) != 0);

	try
	{
		m_pConnection->Execute(_bstr_t(lpstrExec), NULL, adExecuteNoRecords);
	}
	catch(_com_error &e)
	{
		CString errormessage;
        errormessage.Format("連接數據庫失敗!\r\n錯誤信息:%s",e.ErrorMessage());
        AfxMessageBox(errormessage);///顯示錯誤信息
	}
	return true;	
}


bool CADOConnection::IsOpen()
{
	if(m_pConnection )
		return m_pConnection->GetState() != adStateClosed;
	return false;
}

void CADOConnection::Close()
{
	if(IsOpen())
		m_pConnection->Close();
}

// CDB 成員函數

//CADODataset
IMPLEMENT_DYNCREATE(CADODataset, CObject)
CADODataset::CADODataset()
{
	//m_pRecordset.CreateInstance("ADODB.Recordset");
	m_pRecordset = NULL;
	m_pCmd = NULL;
	m_strQuery = _T("");
	m_pRecordset.CreateInstance(__uuidof(Recordset));
	m_pCmd.CreateInstance(__uuidof(Command));
	m_nEditStatus = CADODataset::dbEditNone;
	m_nSearchDirection = CADODataset::searchForward;
}

CADODataset::~CADODataset()
{  
	Close();
	m_pRecordset.Release();
	m_pCmd.Release();
	m_pRecordset = NULL;
	m_pCmd = NULL;
	m_strQuery = _T("");
	m_nEditStatus = dbEditNone;
}

_RecordsetPtr CADODataset::OpenSql(LPCTSTR TblName,LPCTSTR FldList,LPCTSTR Constr,LPCSTR OrderBy)
{  
	//ASSERT(this->m_pAdocon->m_pConnection!=NULL);
   ASSERT(this->m_pConnection!=NULL);
   char sqlstr[256];
   strcpy(sqlstr,"select ");
   strcat(sqlstr,FldList); strcat(sqlstr," from ");
   strcat(sqlstr,TblName);strcat(sqlstr,"  ");
   strcat(sqlstr,Constr);strcat(sqlstr,"  ");strcat(sqlstr,OrderBy);
   if (IsOpen())
   {
	   this->m_pRecordset->Close();
     }
   m_pRecordset->Open((_variant_t) sqlstr,
	                    this->m_pConnection.GetInterfacePtr(),
					   adOpenStatic,
					   adLockOptimistic,
					   adCmdText);
  return m_pRecordset;
}
bool CADODataset::ExecSql(LPCSTR SqlStr)
{
   ASSERT(this->m_pConnection!=NULL);
   ASSERT(this->m_pCmd!=NULL); 
   m_pCmd->ActiveConnection = this->m_pConnection;
   m_pCmd->CommandText = _bstr_t(SqlStr);
   m_pCmd->CommandType = adCmdText;		
   m_pCmd->Execute(NULL, NULL, adCmdText);
   return true;
}
_RecordsetPtr    CADODataset::ExecStoreProc(LPCSTR SqlProc)
{
   ASSERT(this->m_pConnection!=NULL);
   ASSERT(this->m_pCmd!=NULL); 
   m_pCmd->ActiveConnection = this->m_pConnection;
   m_pCmd->CommandText = _bstr_t(SqlProc);
   m_pCmd->CommandType = adCmdStoredProc;		
   this->m_pRecordset=m_pCmd->Execute(NULL, NULL, adCmdText);
   return this->m_pRecordset;
}
void CADODataset::FillList(CListCtrl &ListCtrl1)
{
  	if(this->IsOpen()) 
	{
      ListCtrl1.SetRedraw(false);
	  this->ClearList(ListCtrl1);
	  this->FillColumn(ListCtrl1);
	  this->FillContent(ListCtrl1);
	  ListCtrl1.SetRedraw(true);
	  ListCtrl1.Invalidate();
	}
	else
	{
		AfxMessageBox("記錄集沒有打開!");
	}
}

void CADODataset::ClearList(CListCtrl &ListCtrl1)
{
	 ListCtrl1.DeleteAllItems ();
	
	int nColumnCount = ListCtrl1.GetHeaderCtrl()->GetItemCount();
	// Delete all of the columns.
	for (int i=0;i < nColumnCount;i++)
	{
		ListCtrl1.DeleteColumn (0);
	}
  
}
void CADODataset::FillColumn(CListCtrl &ListCtrl1)
{
	int fieldCount=m_pRecordset->Fields ->Count;
	int fieldLength = 0;
	FieldPtr m_fieldCtl;

	for(int i=0;i<fieldCount;i++)
	{
		m_fieldCtl = m_pRecordset->Fields ->GetItem(long(i));
		fieldLength = m_fieldCtl->DefinedSize*10;
		if (fieldLength >100)   //when field is very long then trim it
		{
			fieldLength = 100;
		}
		else if (fieldLength < 50)
		{
			fieldLength = 50;
		}
		else
		{
		   fieldLength = 80;
		}
		/*
		if (fieldLength < m_fieldCtl->Name.length()*12)
		{
			fieldLength = m_fieldCtl->Name.length()*12;
		}
        */
		ListCtrl1.InsertColumn(i,m_fieldCtl->Name,LVCFMT_LEFT,fieldLength);
	}
   
}

void CADODataset::FillContent(CListCtrl &ListCtrl1)
{
	int nItem = 0;
	FieldPtr m_fieldCtl;
	int fieldCount=m_pRecordset->Fields ->Count;
	_variant_t varValue;
	_bstr_t bstrValue;

	while(!m_pRecordset->adoEOF)
	{
		m_fieldCtl = m_pRecordset->Fields ->GetItem(long(0));
		varValue = m_fieldCtl->Value;
		if (varValue.vt == VT_NULL)
		{
			bstrValue = "";
		}
		else if (varValue.vt==VT_BOOL)
		{
		    if(varValue.boolVal==-1)
			{bstrValue="是";}
			else
			{bstrValue="否";}
		}
		else
		{
			bstrValue=varValue;
		}
		nItem=ListCtrl1.InsertItem(0xffff,bstrValue); //fisrt value

		for(int i=1;i<fieldCount;i++)  //next all value
		{
			m_fieldCtl = m_pRecordset->Fields ->GetItem(long(i));
			varValue = m_fieldCtl->Value;
			if (varValue.vt == VT_NULL)
			{
				bstrValue = "";
			}
			else if (varValue.vt==VT_BOOL)
			{
				if(varValue.boolVal==-1)//-1 true
				{bstrValue="是";}
				else
				{bstrValue="否";}
			}
			else
			{
				bstrValue=varValue;
			}

			ListCtrl1.SetItem(nItem,i,1,bstrValue,NULL,0,0,0);
		}

		m_pRecordset->MoveNext ();
	}

}
bool CADODataset::Open(_ConnectionPtr mpdb, LPCTSTR lpstrExec, int nOption)
{	
	Close();
	
	if(strcmp(lpstrExec, _T("")) != 0)
		m_strQuery = lpstrExec;

	ASSERT(!m_strQuery.IsEmpty());
	
	m_strQuery.TrimLeft();
	BOOL bIsSelect =(m_strQuery.Mid(0, strlen("Select ")).CompareNoCase("select ") == 0);

	try
	{
		m_pRecordset->CursorLocation = adUseClient;
		if(bIsSelect || nOption == openQuery)
			m_pRecordset->Open((LPCSTR)m_strQuery, _variant_t((IDispatch*)mpdb, true), 
							adOpenStatic, adLockOptimistic, adCmdUnknown);
		else if(nOption == openTable)
			m_pRecordset->Open((LPCSTR)m_strQuery, _variant_t((IDispatch*)mpdb, true), 
							adOpenDynamic, adLockOptimistic, adCmdTable);
		else if(nOption == openStoredProc)
		{
			m_pCmd->ActiveConnection = mpdb;
			m_pCmd->CommandText = _bstr_t(m_strQuery);
			m_pCmd->CommandType = adCmdStoredProc;
			
			m_pRecordset = m_pCmd->Execute(NULL, NULL, adCmdText);
		}
		else
		{
			TRACE( "Unknown parameter. %d", nOption);
			return false;
		}
	}
	catch(_com_error &e)
	{
        	
		dump_com_error(e);
		return false;
	}

	return m_pRecordset != NULL;
}

bool CADODataset::Open(LPCTSTR lpstrExec, int nOption)
{
	ASSERT(this->m_pConnection != NULL);
	return Open(this->m_pConnection, lpstrExec, nOption);
}

bool CADODataset::GetFieldValue(LPCTSTR lpFieldName, double& dbValue)
{	
	double val = (double)NULL;
	_variant_t vtFld;
	
	vtFld = m_pRecordset->Fields->GetItem(lpFieldName)->Value;
	if(vtFld.vt != VT_NULL)
		val = vtFld.dblVal;
	dbValue = val;
	return true;
}


bool CADODataset::GetFieldValue(int nIndex, double& dbValue)
{	
	double val = (double)NULL;
	_variant_t vtFld;
	_variant_t vtIndex;

	vtIndex.vt = VT_I2;
	vtIndex.iVal = nIndex;
	
	vtFld = m_pRecordset->Fields->GetItem(vtIndex)->Value;
	if(vtFld.vt != VT_NULL)
		val = vtFld.dblVal;
	dbValue = val;
	return true;
}


bool CADODataset::GetFieldValue(LPCTSTR lpFieldName, long& lValue)
{
	long val = (long)NULL;
	_variant_t vtFld;
	
	vtFld = m_pRecordset->Fields->GetItem(lpFieldName)->Value;
	if(vtFld.vt != VT_NULL)
		val = vtFld.lVal;
	lValue = val;
	return true;
}

bool CADODataset::GetFieldValue(int nIndex, long& lValue)
{
	long val = (long)NULL;
	_variant_t vtFld;
	_variant_t vtIndex;
	
	vtIndex.vt = VT_I2;
	vtIndex.iVal = nIndex;
	vtFld = m_pRecordset->Fields->GetItem(vtIndex)->Value;
	if(vtFld.vt != VT_NULL)
		val = vtFld.lVal;
	lValue = val;
	return true;
}


bool CADODataset::GetFieldValue(LPCTSTR lpFieldName, int& nValue)
{
	int val = NULL;
	_variant_t vtFld;
	
	vtFld = m_pRecordset->Fields->GetItem(lpFieldName)->Value;
	switch(vtFld.vt)
	{
	case VT_I2:
		val = vtFld.iVal;
		break;
	case VT_I4:
		val = vtFld.iVal;
		break;
	case VT_BOOL:
		val = vtFld.boolVal;
		break;
	case VT_NULL:
		val=0;
		break;
	case VT_EMPTY:
		val=0;
		break;
	case VT_BSTR:
		try
		{
		   val=atoi((char*)vtFld.bstrVal);
		   break;
		}
        catch( char* str )
		{
		  AfxMessageBox(str);
		  return 0;
		};
	default:
		nValue = 0;
		return false;
	}	
	nValue = val;
	return true;
}

bool CADODataset::GetFieldValue(int nIndex, int& nValue)
{
	int val = (int)NULL;
	_variant_t vtFld;
	_variant_t vtIndex;
	
	vtIndex.vt = VT_I2;
	vtIndex.iVal = nIndex;
	vtFld = m_pRecordset->Fields->GetItem(vtIndex)->Value;
	switch(vtFld.vt)
	{
	case VT_I2:
		val = vtFld.iVal;
		break;
	case VT_I4:
		val = vtFld.iVal;
		break;
	case VT_NULL:
        val = 0;
		break;
	case VT_BOOL:
		val = vtFld.boolVal;
		break;
	case VT_EMPTY:
		val = 0;
		break;
	default:
		return false;
	}	
	nValue = val;
	return true;
}

bool CADODataset::GetFieldValue(LPCTSTR lpFieldName, CString& strValue)
{
	CString str = _T("");
	_variant_t vtFld;
	
	vtFld = m_pRecordset->Fields->GetItem(lpFieldName)->Value;
	switch(vtFld.vt) 
	{
	case VT_BSTR:
		str = vtFld.bstrVal;
		break;
	case VT_DATE:
		{
			COleDateTime dt(vtFld);

			str = dt.Format("%Y-%m-%d %H:%M:%S");
		}
		break;
	case VT_EMPTY:
          
	case VT_NULL:
		str="";
		break;
	case VT_I1:
		str.Format("%d",vtFld.intVal);
		break;
	case VT_I2:
		str.Format("%d",vtFld.iVal);
		break;
	case VT_I4:
		str.Format("%d",vtFld.intVal);
		break;
	case VT_BOOL:
		if(vtFld.boolVal==-1)
		{str="TRUE";}
		else
		{str="FALSE";}
		break;
	case VT_DECIMAL:
		str.Format("%f",vtFld.decVal);
		break;
	default:
		strValue.Empty();
		return false;
	}
	strValue = str;
	return true;
}

bool CADODataset::GetFieldValue(int nIndex, CString& strValue)
{
	CString str = _T("");
	_variant_t vtFld;
	_variant_t vtIndex;

	vtIndex.vt = VT_I2;
	vtIndex.iVal = nIndex;
	
	vtFld = m_pRecordset->Fields->GetItem(vtIndex)->Value;
	switch(vtFld.vt) 
	{
	case VT_BSTR:
		str = vtFld.bstrVal;
		break;
	case VT_DATE:
		{
			COleDateTime dt(vtFld);
			str = dt.Format("%Y-%m-%d %H:%M:%S");
		}
		break;
	case VT_EMPTY:
		str="";
		break;
	case VT_NULL:
		str="";
		break;
	case VT_I1:
		str.Format("%d",vtFld.intVal);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产另类ts人妖一区二区| 一区二区三区小说| 国产精品天干天干在线综合| 亚洲婷婷在线视频| 免费一级欧美片在线观看| 国产九九视频一区二区三区| 在线精品视频一区二区三四| 欧美一卡2卡三卡4卡5免费| 国产精品自拍毛片| 欧美精品一区二区高清在线观看 | 成人精品一区二区三区四区| 99久久免费精品高清特色大片| 欧美日韩视频在线第一区| 久久精品日产第一区二区三区高清版 | 欧美激情中文字幕| 国产一区二区不卡在线| 91精品国产一区二区三区香蕉| 色婷婷久久99综合精品jk白丝| 久久久久久久久久久久久女国产乱| 麻豆精品精品国产自在97香蕉| 欧美专区在线观看一区| 欧美三级电影在线观看| 蜜桃免费网站一区二区三区| 成人免费黄色在线| 精品国产网站在线观看| 91尤物视频在线观看| 蜜桃视频在线观看一区| 最新不卡av在线| 久久精品一区二区三区av| 一二三四社区欧美黄| 丰满少妇在线播放bd日韩电影| 日韩一区二区在线观看| 欧美视频你懂的| 亚洲日本在线天堂| 91久久线看在观草草青青| www.一区二区| 国产欧美一区二区精品仙草咪| 日韩av中文在线观看| 欧美日韩精品二区第二页| 亚洲美女一区二区三区| 成人高清视频在线| 中文字幕va一区二区三区| 国产福利视频一区二区三区| 久久久不卡影院| 国产宾馆实践打屁股91| 国产日韩欧美一区二区三区综合| 国产在线播放一区二区三区| 精品国产91久久久久久久妲己| 麻豆国产91在线播放| 日韩视频一区二区三区| 蜜桃av一区二区三区| 欧美日韩在线观看一区二区| 亚洲精选在线视频| 欧美激情在线看| 91麻豆swag| 69久久99精品久久久久婷婷| 天堂一区二区在线免费观看| 日韩欧美国产成人一区二区| 国产精品一区专区| 综合精品久久久| 欧美日韩国产经典色站一区二区三区| 亚洲一区二区三区四区五区黄| 欧美色图免费看| 美国十次综合导航| 久久精品一区二区三区不卡| 91在线观看高清| 日日摸夜夜添夜夜添精品视频| 欧美男人的天堂一二区| 老司机精品视频在线| 日韩欧美一级特黄在线播放| 免费观看在线色综合| 欧美α欧美αv大片| 日日摸夜夜添夜夜添亚洲女人| 国产丶欧美丶日本不卡视频| 国产一区999| 91精品欧美一区二区三区综合在 | 麻豆国产欧美一区二区三区| 国产麻豆精品95视频| 国产精品一区二区在线看| 成人免费视频网站在线观看| 在线观看视频欧美| 亚洲婷婷在线视频| 麻豆视频一区二区| 青青草91视频| 91免费观看在线| 一区二区三区毛片| 日韩一区二区麻豆国产| 国产成人在线观看免费网站| 中文字幕不卡在线播放| 欧美亚一区二区| 亚洲国产精品麻豆| 欧美一区二区三区视频在线观看| 狠狠色狠狠色综合系列| 中日韩免费视频中文字幕| 91成人在线观看喷潮| 久久av资源站| ...xxx性欧美| 精品对白一区国产伦| 99在线精品观看| 亚洲专区一二三| 国产亚洲综合在线| 欧美日韩午夜影院| 国产一区二区精品久久99| 一区二区在线观看视频在线观看| 日韩一区二区精品葵司在线 | 国产自产视频一区二区三区| 亚洲天堂精品视频| 精品999在线播放| 91精品办公室少妇高潮对白| 久久99久久久久久久久久久| 日本一区二区三级电影在线观看| 7878成人国产在线观看| 97精品国产露脸对白| 精品在线观看视频| 亚洲一本大道在线| 国产精品夫妻自拍| 精品黑人一区二区三区久久| 色美美综合视频| 国产精品一区在线观看乱码 | 国产精品国产三级国产普通话三级| 欧美日韩不卡一区二区| 成人国产一区二区三区精品| 日韩中文欧美在线| 亚洲精品成人少妇| 国产精品网站在线播放| 精品免费视频.| 欧美一区二区三区视频免费| 成人自拍视频在线| 狠狠色丁香婷婷综合| 日本女优在线视频一区二区| 亚洲欧美乱综合| 国产精品视频一二| 国产欧美一区二区精品婷婷| 精品美女在线播放| 欧美午夜不卡在线观看免费| 日韩欧美国产1| 色伊人久久综合中文字幕| 日本91福利区| 亚洲欧美日韩精品久久久久| 欧美日韩国产天堂| 国产精品夜夜爽| 久久国产剧场电影| 日本欧美肥老太交大片| 日韩精品一区二区三区四区| eeuss鲁一区二区三区| 亚洲视频精选在线| 日韩欧美在线一区二区三区| 99re这里只有精品6| 色婷婷国产精品久久包臀| av亚洲产国偷v产偷v自拍| 不卡的看片网站| 成人午夜电影久久影院| 99久久久久久99| 91免费看片在线观看| 99精品欧美一区| 91成人免费网站| 欧美午夜在线观看| 欧美美女bb生活片| 欧美区视频在线观看| 久久免费美女视频| 中文字幕精品三区| 久久青草国产手机看片福利盒子| 久久精品网站免费观看| 国产精品久久久久久久久免费樱桃| 日韩精品资源二区在线| 国产精品二区一区二区aⅴ污介绍| 亚洲色图视频网站| 日韩精品国产欧美| 精品在线播放免费| 国产91露脸合集magnet | 一本大道av伊人久久综合| 91黄色免费看| 欧美一二区视频| 国产欧美日韩久久| 一区二区成人在线| 久久国产精品一区二区| 精品一区二区三区免费视频| 国产精品资源在线观看| 色综合天天在线| 日韩一区二区在线看| 国产精品久久久久一区二区三区共| 一区二区国产视频| 韩国一区二区三区| 色老汉av一区二区三区| 欧美一区二区三区免费在线看| 国产天堂亚洲国产碰碰| 亚洲精品中文字幕在线观看| 国产精品99久久久久久宅男| 91在线码无精品| 日韩欧美的一区| 亚洲欧美经典视频| 狠狠狠色丁香婷婷综合激情| 色综合久久久久综合| 精品国产乱码久久久久久免费| 国产女主播一区| 精品一区二区成人精品| 色综合久久99| 国产欧美精品一区二区三区四区| 爽好久久久欧美精品| 91农村精品一区二区在线|