⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testview.cpp

📁 跟数据库密切相关的各种典型操作VC例程源代码
💻 CPP
字号:
// TestView.cpp : CTestView 类的实现
//

#include "stdafx.h"
#include "Test.h"

#include "TestDoc.h"
#include "TestView.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CTestView

IMPLEMENT_DYNCREATE(CTestView, CView)

BEGIN_MESSAGE_MAP(CTestView, CView)
	// 标准打印命令
	ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
	ON_WM_RBUTTONDOWN()
	ON_WM_LBUTTONDOWN()
END_MESSAGE_MAP()

// CTestView 构造/销毁

CTestView::CTestView()
{
	// TODO: 在此处添加构造代码

}

CTestView::~CTestView()
{
}

BOOL CTestView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: 在此处通过修改 CREATESTRUCT cs 来修改窗口类或
	// 样式

	return CView::PreCreateWindow(cs);
}

// CTestView 绘制

void CTestView::OnDraw(CDC* /*pDC*/)
{
	CTestDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	// TODO: 在此处为本机数据添加绘制代码
}


// CTestView 打印

BOOL CTestView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// 默认准备
	return DoPreparePrinting(pInfo);
}

void CTestView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: 打印前添加额外的初始化
}

void CTestView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: 打印后添加清除过程
}


// CTestView 诊断

#ifdef _DEBUG
void CTestView::AssertValid() const
{
	CView::AssertValid();
}

void CTestView::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

CTestDoc* CTestView::GetDocument() const // 非调试版本是内联的
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CTestDoc)));
	return (CTestDoc*)m_pDocument;
}
#endif //_DEBUG


// CTestView 消息处理程序
#include <afxdb.h>
void CTestView::OnRButtonDown(UINT nFlags, CPoint point)
{
		CDatabase DB;
	//Excel安装驱动
	CString StrDriver = "MICROSOFT EXCEL DRIVER (*.XLS)"; 
	//要建立的Excel文件
	CString StrExcelFile = "C:\\MyExcel.xls";
	CString StrSQL;
	StrSQL.Format("DRIVER={%s};DSN='';FIRSTROWHASNameS=1;READONLY=FALSE;CREATE_DB=\"%s\";DBQ=%s",StrDriver,StrExcelFile,StrExcelFile);
	TRY
	{		
		// 创建Excel表格文件)
		if(DB.OpenEx(StrSQL,CDatabase::noOdbcDialog) )
		{
			//创建表结构 字段名不能是Index			
			StrSQL = "CREATE TABLE MyExcel (股票代码 TEXT,股票名称 TEXT,收盘价 NUMBER)";
			DB.ExecuteSQL(StrSQL);			
			//插入数值
			StrSQL = "INSERT INTO MyExcel (股票代码,股票名称,收盘价) VALUES ('600006','东风汽车','12.90')";
			DB.ExecuteSQL(StrSQL);
			StrSQL = "INSERT INTO MyExcel (股票代码,股票名称,收盘价) VALUES ('600066','宇通客车','17.60')";
			DB.ExecuteSQL(StrSQL);
			StrSQL = "INSERT INTO MyExcel (股票代码,股票名称,收盘价) VALUES ('600736','苏州高新','7.58')";
			DB.ExecuteSQL(StrSQL);			
		}
		// 关闭数据库
		DB.Close();
	}
	CATCH_ALL(e)
	{
		TRACE1("没有安装Excel驱动: %s",StrDriver);
	}
	END_CATCH_ALL;
	MessageBox("C:\\MyExcel.xls文件创建成功!","信息提示",MB_OK);
	CView::OnRButtonDown(nFlags, point);
}
#include <afxdb.h>
void CTestView::OnLButtonDown(UINT nFlags, CPoint point)
{
		CDatabase DB;	
	CString StrSQL;
	CString StrDsn;
	//将被读取的Excel文件名
	CString StrFile = "C:\\MyExcel.xls";	
	// 创建进行存取的字符串
	StrDsn.Format("ODBC;DRIVER={MICROSOFT EXCEL DRIVER (*.XLS)};DSN='';DBQ=C:\\MyExcel.xls");
	TRY
	{
		// 打开Excel文件)
		DB.Open(NULL, false, false, StrDsn);
		CRecordset DBSet(&DB);
		// 设置读取的查询语句
		StrSQL = "SELECT * FROM MyExcel";		
		//执行查询语句
		DBSet.Open(CRecordset::forwardOnly, StrSQL, CRecordset::readOnly);
		// 获取查询结果		
		CString StrInfo="股票代码  股票名称  收盘价  \n";
		while (!DBSet.IsEOF())
		{
			//读取Excel内部数值			
			for(int i=0;i<DBSet.GetODBCFieldCount();i++)
			{
				CString Str;
				DBSet.GetFieldValue(i, Str);
				StrInfo+=Str+"    ";
			}
			StrInfo+="\n";
			DBSet.MoveNext();
		}
		MessageBox(StrInfo,"信息提示",MB_OK);
		// 关闭数据库
		DB.Close();
	}
	CATCH(CDBException, e)
	{
		// 数据库操作产生异常时...
		AfxMessageBox("数据库错误: " + e->m_strError);
	}
	END_CATCH;
	CView::OnLButtonDown(nFlags, point);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -