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

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

?? textdlg.cpp

?? evc+中文模擬器操作sqlite數據庫
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// textDlg.cpp : implementation file
//

#include "stdafx.h"
#include "text.h"
#include "textDlg.h"
#include "sqlite3.h"
#include "String.h"

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

//---------------------------------------------------------
extern CDatabaseAccess ado;
extern _RecordsetPtr ptr;
//---------------------------------------------------------

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

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()

/////////////////////////////////////////////////////////////////////////////
// CTextDlg dialog

CTextDlg::CTextDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CTextDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CTextDlg)
	m_Sqlsentence = _T("");
	m_frist = true;
	m_edit_values = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
//-----------------------------------------------------------

//-----------------------------------------------------------

	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
CTextDlg::~CTextDlg()
{

}
void CTextDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CTextDlg)
	DDX_Control(pDX, IDC_DATETIMEPICKER_end, m_date_end);
	DDX_Control(pDX, IDC_DATETIMEPICKER_begin, m_deta_begin);
	DDX_Control(pDX, IDC_STATIC_end, m_static_end);
	DDX_Control(pDX, IDC_STATIC_begin, m_static_begin);
	DDX_Control(pDX, IDC_RADIO_all, m_radioall);
	DDX_Control(pDX, IDC_LIST2, m_datalist);
	DDX_Text(pDX, IDC_EDIT_sqlsentence, m_Sqlsentence);
	DDX_Control(pDX, IDC_RADIO_tablename, m_radio_tablename);
	DDX_Text(pDX, IDC_EDIT_values, m_edit_values);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CTextDlg, CDialog)
	//{{AFX_MSG_MAP(CTextDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON_execute1, OnBUTTONexecute1)
	ON_EN_UPDATE(IDC_EDIT_sqlsentence, OnUpdateEDITsqlsentence)
	ON_BN_CLICKED(IDC_RADIO_all, OnRADIOall)
	ON_BN_CLICKED(IDC_RADIO_date, OnRADIOdate)
	ON_BN_CLICKED(IDC_BUTTON_ok, OnBUTTONok)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CTextDlg message handlers

BOOL CTextDlg::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_radioall.SetCheck(1);
	m_radio_tablename.SetCheck(1);
	m_static_begin.ShowWindow(SW_HIDE);
	m_static_end.ShowWindow(SW_HIDE);
	m_deta_begin.ShowWindow(SW_HIDE);
	m_date_end.ShowWindow(SW_HIDE);
//---------------------------------------------------------------------------------
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CTextDlg::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 CTextDlg::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();
	}
}

HCURSOR CTextDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

//執行插入和刪除語句調用本函數
void CTextDlg::OnBUTTONexecute1() 
{
	UpdateData(true);
	OpenSqlite();

	m_Sqlsentence = _T(m_Sqlsentence);
	if(m_Sqlsentence.Left(6) == _T("select") || m_Sqlsentence.Left(6) == _T("Select") ||
		m_Sqlsentence.Left(6) == _T("SELECT"))
	{
		char **errmsg = NULL;
		char **dbResult;
		int nRow, nColumn;
		CString temp = m_Sqlsentence;
		char* sql = temp.GetBuffer(0);
		temp.ReleaseBuffer();

		//取得sqlite里所有表
		if(SQLITE_OK != sqlite3_get_table( db, sql, &dbResult, &nRow, &nColumn, errmsg))
		{
			::MessageBox(NULL,sqlite3_errmsg(db),NULL,MB_OK | MB_ICONERROR);
			sqlite3_close(db);
			sqlite3_free_table( dbResult ); 
			return;
		}
		
		m_inumber = nColumn;
		m_datalist.ModifyStyle(0L,LVS_REPORT);
		m_datalist.ModifyStyle(0L,LVS_SINGLESEL);
		m_datalist.ModifyStyle(0L,LVS_SHOWSELALWAYS);
		m_datalist.ModifyStyle(0L,LVS_NOSORTHEADER);
		m_datalist.SetExtendedStyle(LVS_EX_GRIDLINES);
		
		if (m_frist)
		{
			for (int i = 0; i <nColumn; i++)
			{
				m_datalist.InsertColumn(i,dbResult[i]);
				m_datalist.SetColumnWidth(i,strlen(dbResult[i])+100);
			}
			
			int number = nColumn;
			for (int k = 0; k < nRow; k++)
			{
				m_datalist.InsertItem(k,"");
				for(int j = 0; j < nColumn; j++)
				{
					m_datalist.SetItemText(k, j, dbResult[number]);
					number++;
				}
			}
			m_frist = false;
		}
		sqlite3_free_table( dbResult ); 
	}

	else
	{
		//執行除查詢以外的sql語句
		char* zErrMsg = 0;
		CString temp = m_Sqlsentence;
		char* sql = temp.GetBuffer(0);
		temp.ReleaseBuffer();
		
		if(SQLITE_OK!=sqlite3_exec(db,sql,0,0,&zErrMsg))
		{
			::MessageBox(NULL,sqlite3_errmsg(db),NULL,MB_OK | MB_ICONERROR);
			sqlite3_close(db);
			return;
		}
	}
	sqlite3_close(db);
}

void CTextDlg::OnUpdateEDITsqlsentence() 
{
	m_frist = true;
	m_datalist.DeleteAllItems();
	for (int i = 0; i < m_inumber; i++)
	{
		m_datalist.DeleteColumn(i);
	}
}

void CTextDlg::OnRADIOall() 
{
	// TODO: Add your control notification handler code here
	m_static_begin.ShowWindow(SW_HIDE);
	m_static_end.ShowWindow(SW_HIDE);
	m_deta_begin.ShowWindow(SW_HIDE);
	m_date_end.ShowWindow(SW_HIDE);
}

void CTextDlg::OnRADIOdate() 
{
	// TODO: Add your control notification handler code here
	m_static_begin.ShowWindow(1);
	m_static_end.ShowWindow(1);
	m_deta_begin.ShowWindow(1);
	m_date_end.ShowWindow(1);
}

void CTextDlg::OnBUTTONok() 
{
	_RecordsetPtr ptrTable;
	_RecordsetPtr ptrTableInfo;
	_variant_t var;
	UpdateData(TRUE);
	OpenSqlite();

	//判斷用戶選中的是按表名同步還是按照用戶的sql語句同步----------------------------------
	if(m_radio_tablename.GetCheck())
	{
 		char **tableResult;
		char **fieldResult;
		int nRow, nColumn;
		int TempRow,TempColumn;
		char **errmsg = NULL;
		bool tableexist = false;
		CString tempName;

		//取得sqlite里所有表---------------------------------------------------------------
		CString sql = "SELECT name FROM sqlite_master";
		if(SQLITE_OK != sqlite3_get_table( db, sql, &tableResult, &nRow, &nColumn, errmsg))
		{
			::MessageBox(NULL,sqlite3_errmsg(db),NULL,MB_OK | MB_ICONERROR);
			sqlite3_close(db);
			sqlite3_free_table( tableResult ); 
			return;
		}

		sql = "";
		//循環于sqlite取得的每一個表名-----------------------------------------------------------
		for(int i = 0; i < nRow; i++)
		{
			tempName = tableResult[i+1];
			if(m_edit_values == tempName)
			{
xunhuan:
				tableexist = true;
				CString fieldname = "";
				int iCount = 0;

				//獲取sqlite當前表各個字段名-----------------------------------------------------
				sql = "SELECT * FROM "+ tempName;
				if(SQLITE_OK != sqlite3_get_table( db, sql, &fieldResult, &TempRow, &TempColumn, errmsg))
				{
					::MessageBox(NULL,sqlite3_errmsg(db),NULL,MB_OK | MB_ICONERROR);
					sqlite3_close(db);
					sqlite3_free_table( fieldResult ); 
					return;
				}

				CString strMiddleName;
				for(int j = 0; j < TempColumn; j++)
				{
					strMiddleName += fieldResult[j];
					strMiddleName += " ";
				}
				
				//獲取sql server記錄集信息-----------------------------------------------------------
				ptrTable = ado.ExecuteSQLSentence("SELECT * FROM SysColumns WHERE id = Object_Id('"+ m_edit_values +"')");
				if(!ptrTable->BOF)
					ptrTable->MoveFirst();

				while(!ptrTable->adoEOF)
				{
					var = ptrTable->GetCollect("name");
					if(var.vt!=VT_NULL)
					{
						fieldname += (LPCSTR)_bstr_t(var);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲mv在线观看| 欧美主播一区二区三区美女| 欧美一级黄色片| 日本在线观看不卡视频| 日韩一卡二卡三卡四卡| 国精产品一区一区三区mba视频 | 成人黄色777网| 中文字幕一区在线观看视频| 成人精品免费网站| 亚洲最新在线观看| 7777女厕盗摄久久久| 精品一区二区免费在线观看| 欧美一区在线视频| 国产精品亚洲综合一区在线观看| 国产精品久久久久久久久快鸭| 一本色道**综合亚洲精品蜜桃冫| 亚洲成av人片在线观看| 日韩欧美国产精品一区| 高潮精品一区videoshd| 亚洲精品va在线观看| 欧美顶级少妇做爰| 国产精品一区二区黑丝| 亚洲欧美日韩久久精品| 欧美午夜免费电影| 国产一区二区女| 一区二区三区在线免费视频| 欧美极品美女视频| 国产精品原创巨作av| 亚洲乱码国产乱码精品精可以看| 欧美日韩精品一区二区三区 | 欧美一区二区播放| 成人免费高清视频在线观看| 亚洲一级二级三级| 久久精品欧美一区二区三区麻豆| 欧美中文字幕一二三区视频| 韩国精品一区二区| 一区二区欧美国产| 久久久久久久国产精品影院| 欧美色爱综合网| 色综合欧美在线| 秋霞电影网一区二区| 中文字幕视频一区二区三区久| 在线不卡免费欧美| 99国产欧美另类久久久精品| 另类专区欧美蜜桃臀第一页| 一区二区三区在线看| 国产亚洲综合在线| 欧美喷潮久久久xxxxx| 99久久国产综合色|国产精品| 奇米色一区二区| 亚洲国产精品嫩草影院| 中文字幕精品在线不卡| 欧美成人性战久久| 欧美日韩一区二区三区四区五区| 懂色av一区二区夜夜嗨| 韩国在线一区二区| 免费观看在线色综合| 亚洲第一主播视频| 一区二区三区精品在线| 欧美激情一区不卡| 欧美成人乱码一区二区三区| 欧美另类z0zxhd电影| 91久久国产综合久久| 国产成人精品在线看| 国产曰批免费观看久久久| 天堂成人免费av电影一区| 亚洲精品免费在线| 亚洲激情校园春色| 亚洲男人电影天堂| 一区在线中文字幕| 国产精品网站导航| 国产精品亲子乱子伦xxxx裸| 国产女人水真多18毛片18精品视频| 欧美一级一级性生活免费录像| 欧美日韩精品一区二区| 精品污污网站免费看| 91久久精品一区二区二区| eeuss国产一区二区三区| 成人国产精品免费观看动漫| 国产精品1区二区.| 高清国产一区二区三区| 国产激情视频一区二区在线观看 | 亚洲乱码国产乱码精品精98午夜| 中文字幕在线一区免费| 国产精品久久久久精k8| 亚洲欧美怡红院| 亚洲天堂精品视频| 亚洲最大成人网4388xx| 亚洲一区二区三区视频在线| 亚洲成人免费视| 日韩av在线发布| 久88久久88久久久| 国产精一区二区三区| 成人福利视频在线| 一本大道久久a久久综合| 91黄色免费网站| 欧美日韩亚洲丝袜制服| 日韩欧美国产不卡| 国产日韩欧美精品在线| 亚洲另类在线一区| 天堂成人国产精品一区| 激情五月婷婷综合网| 成人午夜免费电影| 欧洲国内综合视频| 日韩精品中文字幕一区| 国产午夜精品一区二区三区视频| 成人免费在线视频| 午夜视黄欧洲亚洲| 国产主播一区二区| 91久久香蕉国产日韩欧美9色| 欧美久久免费观看| 国产亚洲精品aa午夜观看| 亚洲欧美激情一区二区| 日韩国产精品大片| 成人天堂资源www在线| 欧美日韩一级片网站| 久久综合色8888| 一区二区三区成人| 国模无码大尺度一区二区三区| 91在线精品一区二区三区| 欧美日韩国产综合一区二区| 2欧美一区二区三区在线观看视频| 国产精品国产三级国产a| 日本vs亚洲vs韩国一区三区| www.在线欧美| 日韩免费在线观看| 伊人夜夜躁av伊人久久| 久草精品在线观看| 欧美日韩国产综合草草| 国产精品人成在线观看免费| 日本不卡一二三| 一本到不卡精品视频在线观看| 26uuu另类欧美亚洲曰本| 午夜天堂影视香蕉久久| www.日韩av| 久久中文娱乐网| 日韩和欧美一区二区三区| 成人av在线网站| xvideos.蜜桃一区二区| 亚洲国产成人va在线观看天堂| 国产一区欧美二区| 91精品国产日韩91久久久久久| 亚洲人成精品久久久久| 国产美女视频一区| 91精品国产综合久久久久久漫画 | 国产精品久久午夜| 精品写真视频在线观看| 欧美日韩国产美女| 自拍偷拍欧美激情| 成人在线综合网站| 亚洲精品一区二区三区在线观看| 亚洲国产乱码最新视频| 91社区在线播放| 欧美激情一区二区三区蜜桃视频| 狠狠色综合播放一区二区| 欧美一区二区福利在线| 亚洲黄色片在线观看| 99视频精品在线| 中日韩av电影| 粉嫩aⅴ一区二区三区四区 | 奇米综合一区二区三区精品视频| 欧美性一二三区| 亚洲最新视频在线观看| 欧洲在线/亚洲| 亚洲精品水蜜桃| 色八戒一区二区三区| 亚洲免费观看高清在线观看| 色一情一伦一子一伦一区| 亚洲精品国久久99热| 在线精品视频免费观看| 亚洲影院理伦片| 欧美三级电影网站| 天堂成人免费av电影一区| 欧美一区二区视频在线观看| 日本亚洲最大的色成网站www| 欧美一区二区精品久久911| 蜜桃视频免费观看一区| 欧美不卡视频一区| 国产精品911| 国产精品卡一卡二| 97久久久精品综合88久久| 亚洲桃色在线一区| 欧美综合视频在线观看| 五月激情综合色| 欧美成人乱码一区二区三区| 国产精品综合一区二区三区| 中文成人av在线| 91久久精品国产91性色tv| 婷婷成人综合网| 欧美成人一区二区三区| 懂色av一区二区三区免费观看| 国产精品成人网| 欧美美女bb生活片| 国内久久精品视频| 国产精品国产三级国产专播品爱网 | 欧美日韩国产a| 久久99精品久久只有精品| 国产精品乱人伦| 欧美视频一区二区三区四区 | 国产91精品露脸国语对白|