📄 searchstaff.cpp
字号:
// SearchStaff.cpp : implementation file
//
#include "stdafx.h"
#include "Office.h"
#include "SearchStaff.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CSearchStaff dialog
CSearchStaff::CSearchStaff(CWnd* pParent /*=NULL*/)
: CDialog(CSearchStaff::IDD, pParent)
{
//{{AFX_DATA_INIT(CSearchStaff)
m_beginDate = COleDateTime::GetCurrentTime();
m_endDate = COleDateTime::GetCurrentTime();
m_department = _T("");
m_name = _T("");
m_educationDegree = _T("");
m_sex = _T("");
m_nationality = _T("");
m_duty = _T("");
//}}AFX_DATA_INIT
}
void CSearchStaff::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CSearchStaff)
DDX_Control(pDX, IDC_LIST, m_list);
DDX_Control(pDX, IDC_DUTY, m_dutyCombo);
DDX_Control(pDX, IDC_EDUCATIONDEGREE, m_educationDegreeCombo);
DDX_Control(pDX, IDC_STAFFNAME, m_nameCombo);
DDX_Control(pDX, IDC_DEPARTMENT, m_departmentCombo);
DDX_DateTimeCtrl(pDX, IDC_BEGINDATE, m_beginDate);
DDX_DateTimeCtrl(pDX, IDC_ENDDATE, m_endDate);
DDX_CBString(pDX, IDC_DEPARTMENT, m_department);
DDX_CBString(pDX, IDC_STAFFNAME, m_name);
DDX_CBString(pDX, IDC_EDUCATIONDEGREE, m_educationDegree);
DDX_CBString(pDX, IDC_SEX, m_sex);
DDX_CBString(pDX, IDC_NATIONALITY1, m_nationality);
DDX_CBString(pDX, IDC_DUTY, m_duty);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CSearchStaff, CDialog)
//{{AFX_MSG_MAP(CSearchStaff)
ON_BN_CLICKED(IDC_SEARCH, OnSearch)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CSearchStaff message handlers
BOOL CSearchStaff::OnInitDialog()
{
CDialog::OnInitDialog();
DWORD style;
style=m_list.GetExStyle();
style=(style|LVS_EX_GRIDLINES|LVS_EX_FULLROWSELECT)&(~LVS_EX_CHECKBOXES) ;
m_list.SetExtendedStyle(style);
m_list.InsertColumn(0,"员工编号",LVCFMT_LEFT,100);
m_list.InsertColumn(1,"出生日期",LVCFMT_LEFT,100);
m_list.InsertColumn(2,"职务",LVCFMT_LEFT,100);
m_list.InsertColumn(3,"姓名",LVCFMT_LEFT,100);
m_list.InsertColumn(4,"合同编号",LVCFMT_LEFT,100);
m_list.InsertColumn(5,"合作部门",LVCFMT_LEFT,100);
m_list.InsertColumn(6,"合同期限",LVCFMT_LEFT,100);
m_list.InsertColumn(7,"性别",LVCFMT_LEFT,100);
m_list.InsertColumn(8,"地址",LVCFMT_LEFT,100);
m_list.InsertColumn(9,"邮编",LVCFMT_LEFT,100);
m_list.InsertColumn(10,"婚姻状态",LVCFMT_LEFT,100);
m_list.InsertColumn(11,"电话",LVCFMT_LEFT,100);
m_list.InsertColumn(12,"民族",LVCFMT_LEFT,100);
m_list.InsertColumn(13,"邮箱",LVCFMT_LEFT,100);
m_list.InsertColumn(14,"文化程度",LVCFMT_LEFT,100);
m_list.InsertColumn(15,"QQ号码",LVCFMT_LEFT,100);
m_list.InsertColumn(16,"毕业学校",LVCFMT_LEFT,100);
m_list.InsertColumn(17,"身份证号",LVCFMT_LEFT,100);
m_list.InsertColumn(18,"专业",LVCFMT_LEFT,100);
m_list.InsertColumn(19,"手机",LVCFMT_LEFT,100);
m_list.InsertColumn(20,"工种",LVCFMT_LEFT,100);
m_list.InsertColumn(21,"备注",LVCFMT_LEFT,100);
CString strSQL;
_RecordsetPtr m_pRecordset;
HRESULT hTRes;
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
strSQL="select distinct department from staff";
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((COfficeApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
int i=0;
while(!(m_pRecordset->adoEOF))
{
m_departmentCombo.InsertString(i,((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("department")));
m_pRecordset->MoveNext();
i++;
}
m_pRecordset->Close();
strSQL="select distinct staffName from staff";
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((COfficeApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
i=0;
while(!(m_pRecordset->adoEOF))
{
m_nameCombo.InsertString(i,((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("staffName")));
m_pRecordset->MoveNext();
i++;
}
m_pRecordset->Close();
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CSearchStaff::OnSearch()
{
UpdateData(true);
CString strSQL;
_RecordsetPtr m_pRecordset;
HRESULT hTRes;
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
strSQL="select * from staff";
CString str;
str.Format("%d-%d-%d",m_beginDate.GetYear(),m_beginDate.GetMonth(),m_beginDate.GetDay());
strSQL+=" where birthday>'"+str+"' ";
str.Format("%d-%d-%d",m_endDate.GetYear(),m_endDate.GetMonth(),m_endDate.GetDay());
strSQL+=" and birthday<'"+str+"' ";
if(m_department!="")
{
strSQL+=" and department='"+m_department+"' ";
}
if(m_name!="")
{
strSQL+=" and staffName='"+m_name+"' ";
}
if(m_educationDegree!="")
{
strSQL+=" and educationDegree='"+m_educationDegree+"' ";
}
if(m_sex!="")
{
strSQL+=" and sex='"+m_sex+"' ";
}
if(m_nationality!="")
{
strSQL+=" and nationality='"+m_nationality+"' ";
}
if(m_duty!="")
{
strSQL+=" and duty='"+m_duty+"' ";
}
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((COfficeApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
int i=0;
m_list.DeleteAllItems();
while(!(m_pRecordset->adoEOF))
{
m_list.InsertItem(i,((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("staffID")));
COleDateTime eventDate= m_pRecordset->GetCollect("birthday");
str.Format("%d-%d-%d",eventDate.GetYear(),eventDate.GetMonth(),eventDate.GetDay());
m_list.SetItemText(i,1,str);
m_list.SetItemText(i,2, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("duty")));
m_list.SetItemText(i,3, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("staffName")));
m_list.SetItemText(i,4, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("contractID")));
m_list.SetItemText(i,5, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("department")));
m_list.SetItemText(i,6, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("contractTerm")));
m_list.SetItemText(i,7, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("sex")));
m_list.SetItemText(i,8, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("address")));
m_list.SetItemText(i,9, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("postcode")));
m_list.SetItemText(i,10, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("marriageCondition")));
m_list.SetItemText(i,11, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("telephone")));
m_list.SetItemText(i,12, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("nationality")));
m_list.SetItemText(i,13, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("eMail")));
m_list.SetItemText(i,14, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("educationLevel")));
m_list.SetItemText(i,15, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("QQ")));
m_list.SetItemText(i,16, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("graduateSchool")));
m_list.SetItemText(i,17, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("major")));
m_list.SetItemText(i,18, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("identityNO")));
m_list.SetItemText(i,19, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("mobile")));
m_list.SetItemText(i,20, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("workType")));
m_list.SetItemText(i,21, ((COfficeApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("remark")));
m_pRecordset->MoveNext();
i++;
}
m_pRecordset->Close();
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -