首先是根据要求,做任务三的设计,有过课设教务系统的经验,把账户设计迁移就可,做的事过去了,但经验留下了。
登录页面花了不少时间,因为htmlayout很不熟,前端的经验并不多。但后来没有用单独的登录界面,出于设计和用户的考虑。希望主页展现所有的员工信息,登陆后在展现下属和任务。
一共做了四天,第一天扩展数据库,登录页面和主页。第二天 重做登录和主页,及1,2,3员工主页,admin管理主页。第三天 日志,导出。第四天 导入。
前面主要是对任务二的扩展,日志和导入的部分花的时间更多。
日志:新建日志表,每对任务做处理,就插入日志,查看日志表时显示全部日志。
主要代码:
std::wstring wsOperatorName; //添加日志 std::wstring taskTheme; std::wstring wsAccount=GetValue("[field='account']",L""); CDB::Sql()<<"select empName from g_demo_employee_yxm where account=:account", soci::use(wsAccount),soci::into(wsOperatorName); CDB::Sql()<<"select taskTheme from g_demo_task_yxm where taskID=:taskID", soci::use(taskID),soci::into(taskTheme); std::wstring wslog=wsOperatorName+L"将"+taskTheme+L"改为审核通过"; CDB::Execute("insertLog",taskTheme,wsOperatorName,wslog);
导出,使用库里边的函数即可,很方便。
导入花了不少时间:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 const std::function<std::wstring (std::map<std::wstring, std::wstring> )> cb = [ this ](std::map<std::wstring, std::wstring> mapFieldValue) -> std::wstring { std::wstring wsOperName = mapFieldValue[L "operatorName" ]; //从excel中取值 std::wstring wsOperTime = mapFieldValue[L "operatorTime" ]; std::wstring wsOperTheme = mapFieldValue[L "taskTheme" ]; std::wstring wsLog = mapFieldValue[L "operatorLog" ]; const wchar_t * pszRowTemplate = this ->m_elList.get_attribute( "row_template" ); //处理该行 dom::root_element elRoot( this ->m_elList); dom::element elRowTemp=elRoot.find_first(pszRowTemplate); dom::element elNewRow=elRowTemp.clone(); m_elList.append(elNewRow); SetElementValue(elNewRow, "[field='operatorName']" ,wsOperName.c_str()); SetElementValue(elNewRow, "[field='operatorTime']" ,wsOperTime.c_str()); SetElementValue(elNewRow, "[field='taskTheme']" ,wsOperTheme.c_str()); SetElementValue(elNewRow, "[field='operatorLog']" ,wsLog.c_str()); CDB::Execute( "importLog" ,wsOperTheme,wsOperName,wsLog,wsOperTime); return L "" ; }; if (CFileManage::ImportFile(m_hWnd, L "(operatorName,操作人员)(operatorTime,操作时间)(taskTheme,任务主题)(operatorLog,日志内容)" , L "operatorName,operatorLog" , cb)) { m_elList.xcall( "page_bind" , "task_log_list" ); SysUtils::Alert(L "导入成功" , m_hWnd); }其实不需要理解,也可以做好。但手误敲错符号后,功能不正常,迫使我不得不弄懂每行代码的作用,包括C++中的function,map,库里边ImportFile函数的使用。
2016.8.4
北京 掌上先机