参照书上做的,但因为原书用的数据库是SQL2000的缘故,
新手+菜鸟,数据库已连接,在别的对话框中均可实现查询访问
啥也不说了,代码
// EmpManDlg.cpp : implementation file
//#include "stdafx.h"
#include "HrSys.h"
#include "EmpManDlg.h"
#include "COMDEF.H"
#include "Columns.h"
#include "Column.h"
#include "EmpEditDlg.h"
#include "_recordset.h"
#include "Employees.h"
#include "TransferDlg.h"
#include "Departments.h"
#include "FamilyManDlg.h"
#include "ExpManDlg.h"extern CUsers curUser;#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif/////////////////////////////////////////////////////////////////////////////
// CEmpManDlg dialog
CEmpManDlg::CEmpManDlg(CWnd* pParent /*=NULL*/)
: CDialog(CEmpManDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CEmpManDlg)
//}}AFX_DATA_INIT
}
void CEmpManDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CEmpManDlg)
DDX_Control(pDX, IDC_TYPE_COMBO, m_combo);
DDX_Control(pDX, IDC_TREE1, m_tree);
DDX_Control(pDX, IDC_ADODC1, m_Adodc);
DDX_Control(pDX, IDC_DATAGRID1, m_datagrid);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CEmpManDlg, CDialog)
//{{AFX_MSG_MAP(CEmpManDlg)
ON_CBN_SELCHANGE(IDC_TYPE_COMBO, OnSelchangeTypeCombo)
ON_NOTIFY(TVN_SELCHANGED, IDC_TREE1, OnSelchangedTree1)
ON_BN_CLICKED(IDC_ADD_BUTTON, OnAddButton)
ON_BN_CLICKED(IDC_MODI_BUTTON, OnModiButton)
ON_BN_CLICKED(IDC_DEL_BUTTON, OnDelButton)
ON_BN_CLICKED(IDC_TRANSFER_BUTTON, OnTransferButton)
ON_BN_CLICKED(IDC_FAMILY_BUTTON, OnFamilyButton)
ON_BN_CLICKED(IDC_EXP_BUTTON, OnExpButton)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()/////////////////////////////////////////////////////////////////////////////
// CEmpManDlg message handlersBOOL CEmpManDlg::OnInitDialog() 
{
CDialog::OnInitDialog();

// TODO: Add extra initialization here
//权限控制,如果不是系统管理员则添加、修改和删除按钮置灰
if (curUser.GetUser_type() != 1)
{
GetDlgItem(IDC_ADD_BUTTON)->EnableWindow(FALSE);
GetDlgItem(IDC_MODI_BUTTON)->EnableWindow(FALSE);
GetDlgItem(IDC_DEL_BUTTON)->EnableWindow(FALSE);
GetDlgItem(IDC_TRANSFER_BUTTON)->EnableWindow(FALSE);
GetDlgItem(IDC_EXP_BUTTON)->EnableWindow(FALSE);
GetDlgItem(IDC_FAMILY_BUTTON)->EnableWindow(FALSE);
}
//装入部门信息
dep.Load_dep();

//添加根节点
m_treeImageList.Create(16,16,FALSE,1,0);  //创建CImageList控件
//装入ICON资源
HICON hIcon = ::LoadIcon(AfxGetResourceHandle(), MAKEINTRESOURCE(IDI_ICON1));
m_treeImageList.Add(hIcon);  //将ICON资源添加到CImageList控件中
//将CImageList控件与Tree控件相关联
m_tree.SetImageList(&m_treeImageList, LVSIL_NORMAL);
m_root = m_tree.InsertItem("部门信息");  //添加根节点
//调用AddtoTree() 函数,将所有部门信息添加到Tree控件中
AddtoTree(m_root, 0);
m_tree.Expand(m_root, TVE_EXPAND); //展开根节点
//选中根节点
m_tree.SelectItem(m_root); //设置员工状态属性
m_combo.SetCurSel(0); return TRUE;  // return TRUE unless you set the focus to a control
              // EXCEPTION: OCX Property Pages should return FALSE
}void CEmpManDlg::AddtoTree(HTREEITEM m_node, int UpperId)
{
//使用递归方法将部门添加到TreeView控件中
int i;
HTREEITEM m_child;
//依次访问dep对象中的部门数组,查找满足条件的记录添加到Tree控件中
for(i=0; i<dep.a_UpperId.GetSize(); i++)
{
//@@@@ 打开a_UpperId数组中等于UpperId的元素
//@@@@ 表明此元素为当前根节点的子节点,因此将其添加到Tree控件中,新节点为m_child
//@@@@ 使用SetItemData()函数将部门编号值也保存在新节点中
//@@@@ 以新节点为根节点,再次递归调用AddtoTree()函数,将其子节点添加到Tree控件中
if (UpperId == atoi(dep.a_UpperId.GetAt(i)))
{
m_child = m_tree.InsertItem(dep.a_DepName.GetAt(i), m_node);
m_tree.SetItemData(m_child, atol(dep.a_DepId.GetAt(i)));
AddtoTree(m_child, atoi(dep.a_DepId.GetAt(i)));
}
}
}void CEmpManDlg::Refresh_Data()
{
UpdateData(TRUE);
//从Tree控件中读取部门编号信息
int iDepId;
HTREEITEM node;
node = m_tree.GetSelectedItem();
iDepId = m_tree.GetItemData(node);
//根据部门编号设置SELECT语句
CString cDepId;
cDepId.Format("%d", iDepId);
CString cSource = "SELECT Emp_Id, Emp_Name AS 姓名, Sex AS 性别,";
cSource += " Political_Party AS 政治面貌, Culture_Level 文化程度, Position AS 岗位,";
cSource += " Title AS 职务 FROM Employees WHERE Dep_Id=" + cDepId; //读取员工状态值,并根据它生成SELECT语句的条件
int iType = m_combo.GetCurSel();
CString cType;
cType.Format("%d", iType);
if (iType > 0)
cSource += " AND State=" + cType;
//刷新ADO Data控件的记录源
m_Adodc.SetRecordSource(cSource);
m_Adodc.Refresh(); //设置列宽度
_variant_t vIndex;
vIndex = long(0);
m_datagrid.GetColumns().GetItem(vIndex).SetWidth(0);
vIndex = long(1);
m_datagrid.GetColumns().GetItem(vIndex).SetWidth(50);
vIndex = long(2);
m_datagrid.GetColumns().GetItem(vIndex).SetWidth(30);
vIndex = long(3);
m_datagrid.GetColumns().GetItem(vIndex).SetWidth(57);
vIndex = long(4);
m_datagrid.GetColumns().GetItem(vIndex).SetWidth(60);
vIndex = long(5);
m_datagrid.GetColumns().GetItem(vIndex).SetWidth(60);
vIndex = long(6);
m_datagrid.GetColumns().GetItem(vIndex).SetWidth(60);
}void CEmpManDlg::OnSelchangeTypeCombo() 
{
// TODO: Add your control notification handler code here
Refresh_Data();
}void CEmpManDlg::OnSelchangedTree1(NMHDR* pNMHDR, LRESULT* pResult) 
{
NM_TREEVIEW* pNMTreeView = (NM_TREEVIEW*)pNMHDR;
// TODO: Add your control notification handler code here
Refresh_Data(); *pResult = 0;
}void CEmpManDlg::OnAddButton() 
{
// TODO: Add your control notification handler code here
UpdateData(TRUE); HTREEITEM node;  //用于保存当前节点
node = m_tree.GetSelectedItem(); //取得当前节点值
int iDepId;
iDepId = m_tree.GetItemData(node);
if (iDepId == 0)  //不能在根节点添加员工
{
MessageBox("请选择部门");
return;
} CEmpEditDlg dlg;
//初始化变量
dlg.EmpId = 0;  //员工编号为0,表示添加
dlg.DepId = iDepId; //部门编号
dlg.cSex = "男";  //性别初始化为男
int iState;  //根据当前的员工状态设置编辑对话框中的员工状态
iState = m_combo.GetCurSel();
if (iState == 0)
dlg.iState = 1;
else
dlg.iState = iState;

//添加员工时,将日期控件设置为当天
CTime t = CTime::GetCurrentTime();
dlg.m_Birth = t;
dlg.m_HireDate = t; if (dlg.DoModal() == IDOK)
Refresh_Data();
}void CEmpManDlg::OnModiButton() 
{
// TODO: Add your control notification handler code here
UpdateData(TRUE); if (m_Adodc.GetRecordset().GetEof())
{
MessageBox("请选择要修改的记录!");
return;
}
//读取选择员工的记录
CEmployees emp;
emp.GetData(m_datagrid.GetItem(0));
//将员工数据读取到编辑对话框中
CEmpEditDlg dlg;
dlg.EmpId = emp.GetEmp_Id();
dlg.EmpName = emp.GetEmp_Name();
dlg.DepId = emp.GetDep_Id();
dlg.UpperId = emp.GetUpperId(); dlg.m_EmpName = emp.GetEmp_Name();
dlg.cSex = emp.GetSex();
dlg.m_Nation = emp.GetNationality();
//设置日期数据
int yy=atoi(emp.GetBirth().Left(4));
int mm=atoi(emp.GetBirth().Mid(6,2));
int dd=atoi(emp.GetBirth().Right(2));
CTime t(yy,mm,dd,0,0,0);
dlg.m_Birth = t;
dlg.m_Marital = emp.GetMarital_Condition();
dlg.m_Political = emp.GetPolitical_Party();
dlg.m_Culture = emp.GetCulture_Level();
dlg.m_Family = emp.GetFamily_Place();
dlg.m_Badge = emp.GetBadgeId();
dlg.m_Idcard = emp.GetId_Card();
dlg.m_Office = emp.GetOffice_phone();
dlg.m_Mobile = emp.GetMobile();
dlg.m_File = emp.GetFiles_Keep_Org();
dlg.m_Hukou = emp.GetHukou();  //设置日期数据
yy=atoi(emp.GetHireDate().Left(4));
mm=atoi(emp.GetHireDate().Mid(6,2));
dd=atoi(emp.GetHireDate().Right(2));
CTime tt(yy,mm,dd,0,0,0);
dlg.m_HireDate = tt;

dlg.m_Position = emp.GetPosition();
dlg.m_Title = emp.GetTitle();
CString cId;
cId.Format("%d", emp.GetUpperId());
dlg.m_Upper = emp.GetName(cId);
dlg.m_Contract = emp.GetContract_Duration();
dlg.iState = emp.GetState();
dlg.m_Memo = emp.GetMemo();
dlg.m_Fillperson = emp.GetFillin_Person();
dlg.m_Filltime = emp.GetFillin_Time(); if (dlg.DoModal() == IDOK)
Refresh_Data();
}void CEmpManDlg::OnDelButton() 
{
// TODO: Add your control notification handler code here
if (m_Adodc.GetRecordset().GetEof())
{
MessageBox("请选择要删除的记录!");
return;
}
//读取选择员工的记录
if (MessageBox("是否删除当前记录?","请确认", MB_YESNO) == IDYES)
{
CEmployees emp;
emp.sql_delete(m_datagrid.GetItem(0));
Refresh_Data();
}
}void CEmpManDlg::OnTransferButton() 
{
// TODO: Add your control notification handler code here
if (m_Adodc.GetRecordset().GetEof())
{
MessageBox("请选择记录!");
return;
}
//读取选择员工的记录
CEmployees emp;
emp.GetData(m_datagrid.GetItem(0));
CString cDepId;
cDepId.Format("%d", emp.GetDep_Id());
CDepartments dep;
dep.GetData(cDepId);
//将员工数据读取到调转对话框中
CTransferDlg dlg;
dlg.m_Old = dep.GetDep_name();
dlg.DepId = emp.GetDep_Id();
dlg.cEmpId = m_datagrid.GetItem(0);
if (dlg.DoModal() == IDOK)
Refresh_Data();
}void CEmpManDlg::OnFamilyButton() 
{
// TODO: Add your control notification handler code here
if (m_Adodc.GetRecordset().GetEof())
{
MessageBox("请选择记录!");
return;
}
//读取选择员工的记录
CFamilyManDlg dlg;
dlg.iEmpId = atoi(m_datagrid.GetItem(0));
dlg.m_EmpName = m_datagrid.GetItem(1);
dlg.DoModal();
}void CEmpManDlg::OnExpButton() 
{
// TODO: Add your control notification handler code here
if (m_Adodc.GetRecordset().GetEof())
{
MessageBox("请选择记录!");
return;
}
//读取选择员工的记录
CExpManDlg dlg;
dlg.iEmpId = atoi(m_datagrid.GetItem(0));
dlg.m_EmpName = m_datagrid.GetItem(1);
dlg.DoModal();
}
求帮助!!!!