《VC语言6.0程序设计从入门到精通》第135章


m_strSQL = 〃select * from '〃 + m_strTableName + 〃'〃;
//将变量值保存到控件中
UpdateData(FALSE);
//进行查询
OnExecute();

接下来实现单击某列进行排序的功能 。在程序中要用到两个类:CColumn 和 CColumns 。 
在 CAdoTestView。cpp 的开头,需要加入语句#include 〃column。h〃 和 #include 〃columns。h〃 ,将 
头文件包含进来。
当在 DataGrid 中单击某列时,会激发 HeadClick 消息。下面为此消息添加响应函数:打 
开“ClassWizard ”对话框,在“Class name ”下拉菜单中选择 CAdoTestView,在“Object Ids ” 
下拉列表中选择 IDC_DATAGRID,在“Messages ”下拉列表中选择 HeadClick ,单击“Add
Function ”,采用默认的函数名,然后依次单击“OK ”和“Edit Code ”按钮,定位到函数 void
CAdoTestView::OnHeadClickDatagrid(short ColIndex),代码如下:
void CAdoTestView::OnHeadClickDatagrid(short ColIndex)

// TODO: Add your control notification handler code here
·365 ·
…………………………………………………………Page 377……………………………………………………………
Visual C++ 6。0 程序设计从入门到精通
//得到 DataGrid 中表示各列信息的类
CColumns cols = m_DataGrid。GetColumns();
//此参数用来得到具体某一列
VARIANT index;
//值为 index
index。intVal = ColIndex;
//类型为整型
index。vt = VT_I4;
//得到单击列
CColumn col = cols。GetItem(index);
//得到此列的名字
m_strTableName = col。GetCaption();
//排序必须是在已经建立连接的情况下
if(m_Connection != NULL)

//排序还必须在表名存在的情况下
if(m_strTableName。GetLength() != 0)

//得到查询语句的长度,后面会用到
int nOriginalLength = m_strSQL。GetLength();
//构造新的查询语句
CString strTmp = 〃 order by '〃 + m_strTableName + 〃'〃;
if(isDesc)

strTmp = strTmp + 〃 desc〃;
isDesc = FALSE;

else
isDesc = TRUE;
m_strSQL += strTmp;
//将变量值保存到控件中
UpdateData(FALSE);
//对新的查询语句进行查询
OnExecute();
//恢复原查询语句,这样做是为了再单击别的列,可以对别的列进行排序
m_strSQL。Delete(nOriginalLength; strTmp。GetLength());



至此,所有的代码均已编写完毕 。这段代码已经实现了对数据库的基本操作。可见,用 
·366 ·
…………………………………………………………Page 378……………………………………………………………
第 12 章 数据库开发
ADO 技术进行数据库开发非常方便,且简单易学。同时,DataGrid 控件的使用可以使得程序 
员不再为数据的显示做很多繁琐的事情,从而大大简化了代码的编写。
(4 )运行程序
对程序编译、链接,然后运行(这里要注意,在编译的时候会出现如下的警告: 
msado15。tlh(403) : warning C4146: unary minus operator applied to unsigned type; result still
unsigned 。对此微软在 MSDN 中作了说明,并建议不要理会这个警告),可以看到运行界面如 
图 12…26 所示。
图 12…26 程序运行界面
单击“数据源”按钮,打开如图 12…27 所示的“数据链接属性 ”对话框。单击“提供者” 
选项卡。
图 12…27 “数据源链接属性”对话框 图 12…28 连接 Access 数据
本例中,用来测试的数据库是在 Access 2002 下建立的,在这里要选择“Microsoft Jet 4。0
OLE DB Provider ”,如果是在 Access 97 下建立的,则要选择“Microsoft Jet 3。51 OLE DB
·367 ·
…………………………………………………………Page 379……………………………………………………………
Visual C++ 6。0 程序设计从入门到精通
Provider ”,如果是其他类型数据库,也有相应的 Provider 可以选择。然后单击“下一步”按 
钮,对话框如图 12…28 所示。在这里数据库选择第 2 节建好的数据库 Info。mdb ,单击“确定” 
按钮,数据源设置完成 。可见,利用 组件 DataSourceLocator 设置数据源是非常方便的, 
而在编写程序的时候,也只需要一个 PromptNew() 函数即可。
设好数据源后回到原运行界面,会发现在第一个 Edit 控件栏中已经填好了连接语句 。单 
击“连接”按钮,在左侧的 List Box 控件栏中会出现 Info。mdb 数据库中的“Contact ”和“Personal ” 
两个表的名字,如图 12…29 所示。
图 12…29 刚连接时的界面
如果想看表 Personal 的内容,只需要用鼠标左键单击 List Box 控件栏中的“Personal ”项, 
则在 DataGrid 控件中便会显示出表 Personal 中的所有记录,如图 12…30 所示。
图 12…30 显示表 Personal 中的所有记录
如果需要记录中的详细资料,如王明的联系方式,可利用第 3 节介绍的 SQL 语句,只需 
要在第 2 个 Edit 控件栏中填写 select * from Contact where Name = ’王明’,然后单击“操作” 
·368 ·
…………………………………………………………Page 380……………………………………………………………
第 12 章 数据库开发
按钮,则在 D
小说推荐
返回首页返回目录