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

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

?? dbmanagerdlg.cpp

?? 利用OLEDB以數據庫的方式打開Excell文件
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
// DBManagerDlg.cpp : implementation file
//

#include "stdafx.h"
#include "DBManager.h"
#include "DBManagerDlg.h"
#include "EditDlg.h"
#include "afx.h"
#include "Company.h"
#include "afxwin.h"
#include "QUERY.h"
//#include "CRsGrid.h"

#ifdef _DEBUG

#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif


/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About
CString cs_table_name;
CString field_info;

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL
	
// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDBManagerDlg dialog

CDBManagerDlg::CDBManagerDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CDBManagerDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CDBManagerDlg)
	m_csSQL = _T("");
	m_csListValue = _T("");
	m_phone_num = _T("");
	m_phone_user_name = _T("");
	m_csSQL = "SELECT * FROM ";
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
	m_pTableset = 0;
	m_pColumnset = 0;
	m_pDynamicBulkSet = 0;
	m_iMaxFieldLength = 0;

}

void CDBManagerDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CDBManagerDlg)
	DDX_Control(pDX, IDC_FEIYONG, m_feiyong);
	DDX_Control(pDX, IDC_COMBO_ASSURE_COMPANY, m_assure_company);
	DDX_Control(pDX, IDC_LIST_DB2, m_ListCtrl2);
	DDX_Control(pDX, IDC_LIST_Correspond, m_ListCorrespond);
	DDX_Control(pDX, IDC_LIST_DB, m_ListCtrl);
	DDX_Text(pDX, IDC_EDIT_SQL, m_csSQL);
	DDX_LBString(pDX, IDC_LIST_DB, m_csListValue);
	DDX_Control(pDX, IDC_RSGRIDCTRL_RESULT, m_RsGridResult);
	DDX_Control(pDX, IDC_RSGRIDCTRL_VIEW, m_RsGridView);
	DDX_Text(pDX, IDC_PHONE_NUM, m_phone_num);
	DDX_Control(pDX, IDC_RSGRIDCTRL_VIEW2, m_RsGridView2);
	DDX_Text(pDX, IDC_PHONE_USER_NAME, m_phone_user_name);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CDBManagerDlg, CDialog)
	//{{AFX_MSG_MAP(CDBManagerDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_OPEN_DB, OnOpenDb)
	ON_COMMAND(ID_EDIT_SHOWATA, OnEditShowata)
	ON_LBN_SELCHANGE(IDC_LIST_DB, OnSelchangeListDb)
	ON_BN_CLICKED(IDC_BUT_VIEW1, OnButView1)
	ON_BN_CLICKED(IDC_BUT_VIEW2, OnButView2)
	ON_BN_CLICKED(IDC_BUT_VIEW3, OnButView3)
	ON_BN_CLICKED(IDC_BUT_VIEW4, OnButView4)
	ON_BN_CLICKED(IDC_EXECUTE, OnExecute)
	ON_WM_CANCELMODE()
	ON_BN_CLICKED(IDC_OPEN_CONFIG, OnOpenConfig)
	ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
	ON_NOTIFY(NM_CLICK, IDC_LIST_Correspond, OnClickLISTCorrespond)
	ON_LBN_SELCHANGE(IDC_LIST_Correspond, OnSelchangeLISTCorrespond)
	ON_BN_CLICKED(IDC_TempToWhole, OnTempToWhole)
	ON_BN_CLICKED(IDC_ADDTOLIST, OnAddtolist)
	ON_BN_CLICKED(IDC_BUTTON1, OnDELETEList)
	ON_BN_CLICKED(IDC_BUTTON_HELP, OnButtonHelp)
	ON_LBN_SELCHANGE(IDC_LIST_DB2, OnSelchangeListDb2)
	ON_BN_CLICKED(IDC_BUTTON2, OnButton2)
	ON_BN_CLICKED(IDC_BUTTON_QUERY, OnButtonQuery)
	ON_BN_CLICKED(IDC_UPDATETOTAL, OnUpdatetotal)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDBManagerDlg message handlers

BOOL CDBManagerDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	

//	m_RsGridResult.OrderByColumn( 

	// TODO: Add extra initialization here

	m_ListCorrespond.SetExtendedStyle(LVS_EX_FULLROWSELECT|LVS_EX_GRIDLINES);
	m_ListCorrespond.InsertColumn(0,"總表",LVCFMT_LEFT,60,-1);
	m_ListCorrespond.InsertColumn(1,"總表字段",LVCFMT_LEFT,70,-1);

	m_ListCorrespond.InsertColumn(2,"對應",LVCFMT_LEFT,35);
	m_ListCorrespond.InsertColumn(3,"臨時表",LVCFMT_LEFT,60,-1);

	m_ListCorrespond.InsertColumn(4,"臨時表字段名",LVCFMT_LEFT,80);
	
	
	GetDlgItem(IDOK)->EnableWindow(FALSE);
	GetDlgItem(IDC_BUTTON_QUERY)->EnableWindow(FALSE);
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CDBManagerDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CDBManagerDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CDBManagerDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}
CString CDBManagerDlg::GetDSN()
{
	if (!m_Database.IsOpen())
		return _T("[No Data Source Selected]");

	// pull DSN from database connect string
	CString string = m_Database.GetConnect();
	string = string.Right(string.GetLength() - (string.Find(_T("DSN=")) + 4));
	string = string.Left(string.Find(_T(";")));
	return string;
}
int CDBManagerDlg::GetProfileValue(LPCTSTR lpszSection,LPCTSTR lpszItem)
{
	int nValue = AfxGetApp()->GetProfileInt(lpszSection,lpszItem,-1);
	if (nValue == -1)
	{
		nValue = 0;
		AfxGetApp()->WriteProfileInt(lpszSection,lpszItem,nValue);
	}
	return nValue;
}
void CDBManagerDlg::FetchColumnInfo(CString lpszName,CRsGrid &m_RsGridView)
{
	if (m_pColumnset)
	{
		if (m_pColumnset->IsOpen())
			m_pColumnset->Close();
		delete m_pColumnset;
		m_pColumnset = 0;
	}


	if (m_pDynamicBulkSet)
	{
		if (m_pDynamicBulkSet->IsOpen())
			m_pDynamicBulkSet->Close();
		delete m_pDynamicBulkSet;
		m_pDynamicBulkSet = 0;
	}



	m_pColumnset = new CColumns(&m_Database);
	m_pColumnset->Open(NULL,NULL,lpszName,NULL,CRecordset::snapshot);

	//insert table Info into RsGrid
	int item = 1;
//	m_RsGridView.SetColCount( 3 );
	m_RsGridView.SetColCount( 1 );
	m_RsGridView.SetCellText( 0, 0, "字段名");
//	m_RsGridView.SetCellText( 0, 1, "字段屬性");
//	m_RsGridView.SetCellText( 0, 2, "字段長度");

	while( m_RsGridView.GetCellText( 1, 1 ) != "" )
	{
		m_RsGridView.DeleteRow( 1, 1 );
	}

	int iRowCount =  m_RsGridView.GetRowCount();
	if( iRowCount == 1 )
		m_RsGridView.InsertRow( 0, 1 );

	m_pColumnset->MoveFirst();
	while (!m_pColumnset->IsEOF())
	{
		m_RsGridView.SetCellText( item, 0, m_pColumnset->m_strColumnName );
		m_csFieldName += m_pColumnset->m_strColumnName;
		m_csFieldName += ",";
//		m_RsGridView.SetCellText( item, 1, m_pColumnset->m_strTypeName );
//		m_csFieldType += m_pColumnset->m_strTypeName;
//		m_csFieldType += ",";
//		m_RsGridView.SetCellNumber( item, 2, m_pColumnset->m_nLength );
//		CString csLenth;
//		csLenth.Format( "%d", m_pColumnset->m_nLength );
//		m_csFieldLength += csLenth;
//		m_csFieldLength += ",";
		m_RsGridView.InsertRow( item, 1 );
		item++;
		m_pColumnset->MoveNext();
	}

}

BOOL CDBManagerDlg::FetchTableInfo()
{
	m_pTableset = new CTables(&m_Database);

	// Must use char array for ODBC interface
	// (can simply hard code max size)
	char lpszType[64];

	strcpy(lpszType, "'TABLE'");
	strcat(lpszType, ",'VIEW'");
	strcat(lpszType, ",'SYSTEM TABLE'");
	strcat(lpszType, ",'ALIAS','SYNONYM'");

	if (!m_pTableset->Open(NULL,NULL,NULL,lpszType,CRecordset::snapshot))
	{
		delete m_pTableset;
		m_pTableset = NULL;
		m_Database.Close();
		return FALSE;
	}

	//show Table Info
	
	int iTemp = 0;
	int iTemp2 = 0;
	m_pTableset->MoveFirst();

	CString m_wholetable ;
			m_wholetable = biaoming;
			m_wholetable += "$";

	while (!m_pTableset->IsEOF())
	{
		if( m_pTableset->m_strTableType == "TABLE" || m_pTableset->m_strTableType == "SYSTEM TABLE" )
		{	
			CString m_ShowTable =m_pTableset->m_strTableName;
			
			if (m_ShowTable[0]==0x27)
			{
				m_ShowTable=m_ShowTable.Right(m_ShowTable.GetLength()-1);
				m_ShowTable=m_ShowTable.Left(m_ShowTable.GetLength()-1);
				
			}

			if (m_ShowTable==m_wholetable)	
			{	
					m_ListCtrl.InsertString( iTemp, m_ShowTable );
					iTemp++;
			}
			else			
			{
				m_ListCtrl2.InsertString( iTemp2, m_ShowTable);
				iTemp2++;
			}
		}
		
		m_pTableset->MoveNext();

	}

	return TRUE;
}

void GetExcelDriver( CString &csExcelDriver )
{
	char szBuf[2001];
	WORD cbBufMax = 2000;
	WORD cbBufOut;
	char *pszBuf = szBuf;

	// Get the names of the installed drivers ("odbcinst.h" has to be included )
	if(!SQLGetInstalledDrivers(szBuf,cbBufMax,& cbBufOut))
	{
		csExcelDriver = "";
	}
	
	// Search for the driver...
	do
	{
		if( strstr( pszBuf, "Excel" ) != 0 )
		{
			// Found !
			csExcelDriver = CString( pszBuf );
			break;
		}
		pszBuf = strchr( pszBuf, '\0' ) + 1;
	}
	while( pszBuf[1] != '\0' );
}


BOOL CDBManagerDlg::OnOpenDb()
{
	// close the database
	if (m_Database.IsOpen())
		m_Database.Close();


///////////////////////////////////////////////////
	CFileDialog m_ExcelDlg(TRUE,NULL,NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, NULL,NULL); 

	if ( IDOK == m_ExcelDlg.DoModal()) 
		{ 
			CString m_Excelpath=m_ExcelDlg.GetPathName();
			CString m_filename=m_ExcelDlg.GetFileName();
			CString m_csfpath=m_Excelpath;
		
			CString csExcelDriver;
			CString sDriver;
			CString sDsn;	

			// 檢索是否安裝有Excel驅動 "Microsoft Excel Driver (*.xls)" 
   			GetExcelDriver(csExcelDriver);
			sDsn.Format("DRIVER={%s};DSN='';FIRSTROWHASNAMES=1;READONLY=FALSE;CREATE_DB=\"%s\";DBQ=%s", csExcelDriver, m_csfpath, m_csfpath);
			if (m_Database.OpenEx(sDsn, CDatabase::noOdbcDialog))
			{
				if (FetchTableInfo() )
				{
					GetDlgItem( IDC_OPEN_DB )->EnableWindow(FALSE);
					m_kuming=kuming;
					m_kuming=m_kuming+".xls";
					if (m_filename==m_kuming)
					{
						GetDlgItem( IDOK )->EnableWindow(TRUE);
						GetDlgItem(IDC_BUTTON_QUERY)->EnableWindow(TRUE);
						//在擔保公司下拉菜單中顯示所有的公司名稱
						CString SQl1,m_biaoming_company;
						CRecordset rs(&m_Database);
						m_biaoming_company=biaoming;
						SQl1="select distinct [擔保公司] from ["+m_biaoming_company+"$]";
						rs.Open(CRecordset::dynaset,(SQl1));
						while (!rs.IsEOF())
						{
							CString content_value;
							rs.GetFieldValue((int)0,content_value);
							m_assure_company.AddString(content_value);
							rs.MoveNext();
						}
						int assure_company_count=rs.GetRecordCount();
						rs.Close();
						return TRUE;
					}
				}
				else
					return FALSE;
			}
			return FALSE;
	}
}

void CDBManagerDlg::OnEditShowata() 
{

	int iNowSel = m_ListCtrl.GetCurSel();
	CString csNowSel;
	m_ListCtrl.GetText( iNowSel, csNowSel.GetBuffer(0) );

	CDynamicBulkSet rs(&m_Database);
	CDataDialog dlgData;

	// Get the current table selected and validate

	CString strSQL;
	strSQL.Format("SELECT * FROM %s", csNowSel);

	// Open the recordset, create the dialog and hand it the recordset
	rs.Open(CRecordset::snapshot, strSQL,
		CRecordset::readOnly | CRecordset::useMultiRowFetch);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
3d成人动漫网站| 久久久精品免费免费| 欧美成人精精品一区二区频| 国产亚洲欧美色| 亚洲中国最大av网站| 国产麻豆精品一区二区| 在线观看视频欧美| 日本一区二区三级电影在线观看| 婷婷一区二区三区| a亚洲天堂av| 久久精品在线观看| 日韩国产在线一| 在线看不卡av| 国产精品美女久久久久高潮| 美女在线一区二区| 欧美日韩美少妇| 一区二区欧美视频| 成人福利视频在线看| 精品久久久久久久人人人人传媒| 午夜视频一区二区| 色哟哟一区二区三区| 中文字幕二三区不卡| 韩国精品免费视频| 日韩一区二区麻豆国产| 日日摸夜夜添夜夜添国产精品| 色综合天天在线| 亚洲女爱视频在线| 一本色道a无线码一区v| 中文字幕中文乱码欧美一区二区| 国产麻豆一精品一av一免费| 久久久精品影视| 国产精品18久久久久久vr| 日韩女优制服丝袜电影| 久久国内精品视频| 精品88久久久久88久久久| 美国十次了思思久久精品导航| 日韩欧美色电影| 精品在线你懂的| 欧美精品一区男女天堂| 激情文学综合丁香| 久久久精品免费观看| 粉嫩av一区二区三区| 国产精品嫩草99a| a4yy欧美一区二区三区| 一区二区在线观看不卡| 色婷婷精品久久二区二区蜜臂av | 自拍偷拍亚洲综合| 99久久久免费精品国产一区二区| 中文字幕在线观看不卡| 在线日韩av片| 日av在线不卡| 久久精品夜色噜噜亚洲a∨| 国产一区二区精品久久99| 欧美激情一区三区| 在线看一区二区| 美女视频一区二区三区| 国产人成一区二区三区影院| 91小视频免费看| 午夜伦理一区二区| 久久久亚洲高清| 色综合中文字幕| 日本亚洲电影天堂| 亚洲国产成人一区二区三区| 在线视频一区二区免费| 免费国产亚洲视频| 国产精品久久久久四虎| 在线91免费看| 成人看片黄a免费看在线| 一区二区三区加勒比av| 欧美第一区第二区| 91在线porny国产在线看| 日本 国产 欧美色综合| 中文字幕一区在线观看| 91精品福利在线一区二区三区| 国产a精品视频| 婷婷六月综合亚洲| 1000精品久久久久久久久| 91精品国产综合久久福利| av一区二区三区| 久久66热偷产精品| 亚洲一区在线电影| 中文字幕第一页久久| 欧美一区二区在线视频| 波多野结衣的一区二区三区| 琪琪久久久久日韩精品| 亚洲精品国产成人久久av盗摄| www日韩大片| 色噜噜偷拍精品综合在线| 精品制服美女丁香| 日韩精品三区四区| 中文字幕亚洲综合久久菠萝蜜| 精品盗摄一区二区三区| 欧美日韩国产高清一区| av在线不卡网| 国产成人av自拍| 久久99日本精品| 欧美aaaaa成人免费观看视频| 一区二区三区中文字幕精品精品| 欧美激情一区二区| 精品国产99国产精品| 欧美精品三级日韩久久| 在线日韩一区二区| 91久久国产最好的精华液| 不卡的av中国片| 成人免费视频视频在线观看免费| 免费在线观看成人| 日韩高清在线电影| 日韩精品欧美成人高清一区二区| 亚洲一级片在线观看| 一级做a爱片久久| 亚洲欧美一区二区三区国产精品 | 亚洲精选视频在线| 亚洲国产精品av| 中文字幕久久午夜不卡| 国产偷国产偷精品高清尤物| 久久免费看少妇高潮| 2021中文字幕一区亚洲| 国产亚洲欧洲997久久综合 | 懂色av中文一区二区三区 | 丁香激情综合国产| 国产aⅴ精品一区二区三区色成熟| 国内久久精品视频| 久久99久久久欧美国产| 国产一区免费电影| 粉嫩绯色av一区二区在线观看| 春色校园综合激情亚洲| av网站免费线看精品| 色呦呦一区二区三区| 欧美日韩亚洲高清一区二区| 7777精品伊人久久久大香线蕉完整版| 欧美老女人第四色| 日韩欧美亚洲国产另类 | 欧美放荡的少妇| 欧美一区二区成人| 26uuu亚洲综合色| 国产精品美日韩| 亚洲午夜久久久久久久久电影网| 天堂av在线一区| 激情深爱一区二区| av一二三不卡影片| 欧美久久一二区| 久久综合网色—综合色88| 国产精品剧情在线亚洲| 亚洲国产成人精品视频| 韩国一区二区在线观看| aaa欧美日韩| 日韩欧美在线网站| 国产日韩一级二级三级| 亚洲在线中文字幕| 国产自产v一区二区三区c| 成人国产精品免费网站| 欧美视频一二三区| 久久精品在线免费观看| 亚洲成人在线网站| 国产精品66部| 91精品国产手机| 中文文精品字幕一区二区| 亚洲成av人片在线| 国产成人精品免费看| 正在播放亚洲一区| 成人免费在线观看入口| 久久精品国产秦先生| 欧美在线小视频| 久久精品视频一区| 日韩专区欧美专区| 99久久精品国产网站| 精品少妇一区二区三区在线播放| 亚洲丝袜美腿综合| 精品一区二区三区免费播放 | 亚洲国产成人porn| 成人动漫视频在线| 日韩一区二区三区视频在线 | 99精品视频在线播放观看| 日韩欧美国产电影| 一区二区三区高清| 丁香网亚洲国际| 2021中文字幕一区亚洲| 日本不卡视频一二三区| 欧美性极品少妇| 综合av第一页| 成人av网站在线观看免费| 精品嫩草影院久久| 男人的天堂久久精品| 欧美精品xxxxbbbb| 亚洲国产一二三| 91蝌蚪porny成人天涯| 中日韩免费视频中文字幕| 国产中文字幕精品| 日韩欧美区一区二| 青青草91视频| 日韩午夜激情视频| 日本一区中文字幕| 欧美男同性恋视频网站| 亚洲第四色夜色| 欧美三级一区二区| 亚洲五月六月丁香激情| 在线视频欧美精品| 亚洲午夜精品在线| 欧美精品一二三| 全国精品久久少妇|