- 浏览: 33744 次
- 性别:
- 来自: 上海
-
最新评论
-
zhongxuchen:
感谢大家的评价,sqltoy在大家刚接触的时候多少会存在一些心 ...
讲述最值得你了解的sqltoy-orm最佳查询实践 -
chenbaixing8:
从事5年多得开发了,自从项目用了sqltoy后感觉效率快得不行 ...
讲述最值得你了解的sqltoy-orm最佳查询实践 -
hong_zhiliang:
使用sqlToy已经有一段时间了,真正解决实际项目中碰到的一些 ...
讲述最值得你了解的sqltoy-orm最佳查询实践 -
luckywang168:
接触这个orm框架有段时间了,新人上手很快,省去了mybati ...
讲述最值得你了解的sqltoy-orm最佳查询实践 -
chenbingbing:
目前公司的报表系统就是采用的楼主的sqlToy,不得不说楼主的 ...
讲述最值得你了解的sqltoy-orm最佳查询实践
excel-tools是用来将excel文件导入到数据库、将数据库文件导出成excel以及数据库表数据库互导的强大工具
目前excel-tools改名为excelToy,excelToy刚刚经历建行项目数据移植的考验,成功将旧系统的数据库中(sqlserver2000)的数据移植到oracle10g中,因为系统是彻底重构,数据库表彻底重新设计,而原系统数据需要移植过来,excelToy正好派上用场。
简单介绍一下excelToy的诞生背景:
excelToy设计的目的用于项目试运行前的数据准备阶段,它是sagacity(睿智)j2ee开发平台中的一个组成部分。
一般情况下一个系统上线前需要做初始化一些系统数据,如数据字典、机构、人员、权限,以及一些历史的资料档案(如考试系统,需要初始化试卷库)等等,一般数据准备我们会以excel文件为介质,所以需要将excel数据导入到数据库中。
在此解答几个问题:
1、为什么不用界面维护呢?少量数据维护还好,大量数据维护客户一定会跟你急,另外项目可能只是测试阶段这些准备数据会经常被重新导入,让别人维护一次人家还好说,再维护一次肯定骂死你。
2、为什么不维护一次后从数据库中导出来,以后再重新导呗!
答:很多时候初始化的数据会不停的改变,如人员信息,过两天客户给你一个新的excel文件,客户只会给你提供excel,他不可能帮你改导出的sql文件的
3、写一个程序挨个读excel导呗
答:那可能得写一大堆代码,不通用,下一个项目又得改代码。
总之以上等等等的因素导致了excelToy的诞生。
excelToy包含以下几个功能:
1、将数据库的表按关联关系输出到xml文件中,此功能的目的在于为其他任务提供数据导入的顺序
2、数据导出,可以将sql语句查询结果以及表清单(当然最终也是sql,即select * from table)的数据全部导出存放于指定目录的excel文件中
3、数据导入,将excel文件数据通过eql语句写入到数据库中
4、数据库修改,以excel数据替换到sql语句中,并执行sql完成对数据库的修改
另外excelToy的最大特点是引入转换器概念,比方将excel中的男女转换成F、M,我们将引入一个枚举转换器
<convert id="SexEnum" extend="enum">
<param name="enumKeys">女</param>
<param name="enumValues">F</param>
<param name="other">M</param>
</convert>
我们导入任务中的EQL语句定义,粗体部分:
(
${UserID},${EmployeeCode},${UserName},${level},${LoginName},
${priceType},@SexEnum(${Gender}),
${Description},${Email},
${PhoneNumber}, ${AttachDepartmentID},${useDeptId},@MobileSubStr(${celltelephone}),
${utmost},${person_code},
${ModifyPerson}, ${ModifyDate} , ${startdate},
${enddate},@deptEnum(${delFlag}),${pmslogin})
into SYS_USER_INFO (
USER_ID, USER_CODE,NAME,LEVEL_ID,ENGLISH_NAME,
PRICE_TYPE, SEX,
COMMENTS, EMAIL,
TELEPHONE,DEPT_ID,WORK_DEPT_ID, MOBILE_NO,
MAX_DAY_WORK_HOURS, IDENTITY_ID,
UPDATE_BY, UPDATE_DATE,INDUTY_DATE,
OUTDUTY_DATE , ENABLED, PMS_ID)
基本配置效果如下:
<?xml version="1.0" encoding="UTF-8"?>
<sagacity>
<!-- 配置数据源 -->
<include file="config/excel-database.xml"/>
<!-- 设置execl最大导出行数 -->
<property name="export.sheet.maxcount" value="4000"/>
<property name="resPool" value="21"/>
<property name="task.auto.disabled" value="false"/>
<convert id="organNoSeq" extend="sequence"/>
<convert id="organLineSeq" extend="sequence"/>
<convert id="SexEnum" extend="enum">
<param name="enumKeys">0</param>
<param name="enumValues">F</param>
<param name="other">M</param>
</convert>
<convert id="DictDataTypeEnum" extend="enum">
<param name="enumKeys">字符串,数字,日期</param>
<param name="enumValues">0,1,2</param>
<param name="other">0</param>
</convert>
<convert id="sagResourceeEnum" extend="enum">
<param name="enumKeys">模块,功能菜单</param>
<param name="enumValues">1,2</param>
<param name="other">1</param>
</convert>
<convert id="deptEnum" extend="enum">
<param name="enumKeys">0,1</param>
<param name="enumValues">1,0</param>
<param name="other">1</param>
</convert>
<convert id="MobileSubStr" extend="substr">
<param name="beginIndex">0</param>
<param name="endIndex">18</param>
</convert>
<convert id="StatusSubStr" extend="substr">
<param name="beginIndex">0</param>
<param name="endIndex">1</param>
</convert>
<convert id="NullConvert" extend="enum">
<param name="enumKeys">null</param>
<param name="enumValues"/>
</convert>
<convert id="DeptTreeRoute" extend="treeRoute">
<param name="rootId" value="-1"/>
<param name="nodeRouteField" value="NODE_ROUTE"/>
<param name="nodeLevelField" value="NODE_LEVEL"/>
<param name="nodeRouteHasSelfField" value="NODE_ROUTE_SELF"/>
<param name="isChar" value="false"/>
<param name="size" value="8"/>
</convert>
<convert id="sagResouceTreeRoute" extend="treeRoute">
<param name="rootId" value="-1"/>
<param name="nodeRouteField" value="TREE_ROUTE"/>
<param name="nodeLevelField" value="NODE_LEVEL"/>
<param name="isChar" value="false"/>
<param name="size" value="8"/>
</convert>
<convert id="capabilityTreeRoute" extend="treeRoute">
<param name="rootId" value="-1"/>
<param name="nodeRouteField" value="NODE_ROUTE"/>
<param name="nodeLevelField" value="NODE_LEVEL"/>
<param name="nodeRouteHasSelfField" value="NODE_ROUTE_SELF"/>
<param name="isChar" value="false"/>
<param name="size" value="8"/>
<param name="leafField" value="IS_LEAF"/>
</convert>
<convert id="dateFormat" extend="dateFormat">
<param name="format" value="yyyy-MM-dd"/>
<param name="dataType" value="String"/>
</convert>
<convert id="sysdateFormat" extend="dateFormat">
<param name="format" value=" yyyy-mm-dd hh:mm:ss.fffffffff"/>
<param name="dataType" value="String"/>
</convert>
<convert id="CalendarFlagEnum" extend="enum">
<param name="enumKeys">1,2</param>
<param name="enumValues">0,1</param>
<param name="other">0</param>
</convert>
<convert id="myTrim" extend="trim">
</convert>
<convert id="systreeMap" extend="treeMap">
<param name="idIndex" value="1"/>
<param name="dynId" value="true"/>
<param name="idNameIndex" value="2"/>
</convert>
<convert id="systreePoolMap" extend="treeMap">
<param name="idIndex" value="1"/>
<param name="dynId" value="true"/>
<param name="idNameIndex" value="3"/>
</convert>
<convert id="sagResouceMap" extend="treeMap">
<param name="idIndex" value="1"/>
<param name="dynId" value="true"/>
<param name="idNameIndex" value="4"/>
</convert>
<convert id="myTableSequence" extend="tableSequence">
</convert>
<convert id="mydict" extend="dict">
<param name="sql">
<![CDATA[select CAPABILITY_ID from SYS_CAPABILITY where name='#{keyParam}']]>
</param>
</convert>
<convert id="myCapdict" extend="dict">
<param name="sql">
<![CDATA[select DICT_KEY from sag_dict_detail where dict_type_code='CAPABILITY_LEVEL' and DICT_NAME='#{keyParam}']]>
</param>
</convert>
<convert id="myPoolId" extend="dict">
<param name="sql">
<![CDATA[select t1.pool_id from sys_res_pool t1 where t1.pool_name='#{keyParam}']]>
</param>
</convert>
<convert id="workCal" extend="dict">
<param name="sql">
<![CDATA[select DICT_KEY from sag_dict_detail where dict_type_code='SYS_WORKCALENDAR_NAME_TYPE' and DICT_NAME='#{keyParam}']]>
</param>
</convert>
<outputTables id="task0" datasource="pias" file="pias.xml" active="false"/>
<export id="exportXMLTables" datasource="old_pmccenter" blobSave="false" active="false" maxLimit="200000" mapping-tables="PMCCENTER_TABLE.xml" dist="deployData/system">select * from taskassignment b where b.taskid in (select a.taskid from tasksheet a)</export>
<!-- ########################## 资源信息表的导出(加入了使用部门ID) ###################-->
<export id="exportSagUser" datasource="old_pmccenter" blobSave="false" active="true" maxLimit="200000" dist="deployData/system/资源信息.xls"> <![CDATA[
select t.* ,
(select DepartmentID from UserWorkDepartment d where d.UserID=t.UserID)as useDeptId from UserInfo t
]]> </export>
<!-- ########################## 资源级别的导出 ###################-->
<export id="exportUserLevel" datasource="old_pmccenter" blobSave="false" active="true" maxLimit="200000" dist="deployData/system/资源级别报价.xls"> <![CDATA[
select * from sys_person_level
]]> </export>
<!-- ########################## 部门信息的导出 ###################-->
<export id="exportDept" datasource="old_pmccenter" blobSave="false" active="true" maxLimit="200000" dist="deployData/system/部门信息.xls"> <![CDATA[
select * from Department
]]> </export>
<!-- ########################## 部门负责人的导出 ###################-->
<export id="exportDeptMaster" datasource="old_pmccenter" blobSave="false" active="true" maxLimit="200000" dist="deployData/system/部门负责人.xls"> <![CDATA[
select * from DepartmentAccess
]]> </export>
<!-- ###################行政日历表数据信息表的导入#####################################-->
<import id="sys_workcallendar" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" fkFilter="true" dist="deployData/system" files="行政日历.xls$">
<do>
<mainTable><![CDATA[(
${日历编号},@workCal(keyParam:${日历名称}),${开始时间},${结束时间},@CalendarFlagEnum(${工作日标识})
) into SYS_WORK_CALENDAR(
CAL_ID,CAL_NAME,BEGIN_DATE,END_DATE,IS_HOLIDAY
)]]> </mainTable>
</do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_WORK_CALENDAR})
</end-do>
</import>
<!-- #####################################职能信息表的导入#####################################-->
<import id="sys_capability" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" fkFilter="true" dist="deployData/system" files="职能信息.xls$">
<pre-do>delete from SYS_RES_POOL_USER </pre-do>
<pre-do>delete from SYS_CAPABILITY_LEVEL </pre-do>
<pre-do>delete from SYS_RES_POOL_CAPABILITY </pre-do>
<pre-do>delete from SYS_DEPARTMENT_MASTER </pre-do>
<pre-do>delete from SYS_RES_POOL_MASTER </pre-do>
<pre-do>delete from SYS_RES_POOL </pre-do>
<do>
<mainTable><![CDATA[(
@organNoSeq(capabilityID),@myTrim(${职能名称}),@systreeMap(${上级职能名称}),${显示顺序},
"",0,1,${描述},${启用标志}
) into SYS_CAPABILITY(
CAPABILITY_ID,NAME,PARENT_CAPABILITY_ID,SHOW_ORDER,
NODE_ROUTE,NODE_LEVEL,IS_LEAF,COMMENTS,ENABLED
)]]> </mainTable>
<!-- 添加子表 -->
<subTables>
<subTable loop-column="对应职级" split="," as="职级">
<![CDATA[
(@myCapdict(keyParam:#{职级}),#{CAPABILITY_ID},1,100,100) into SYS_CAPABILITY_LEVEL
(CAPABILITY_LEVEL_ID,CAPABILITY_ID,ENABLED,CAPABILITY_WORK_RATE,CAPABILITY_LEVEL_NAME)
]]>
</subTable>
</subTables>
</do>
<!-- 计算节点路径和节点级别-->
<end-do>@capabilityTreeRoute({tableName:SYS_CAPABILITY,idField:CAPABILITY_ID,pidField:PARENT_CAPABILITY_ID})</end-do>
<!--更新级别名称 -->
<end-do>
update sys_capability_level t set t.capability_level_name=
(select dict_name from sag_dict_detail d where d.dict_type_code='CAPABILITY_LEVEL' and d.dict_key=t.capability_level_id )
</end-do>
<!--插入没有职级的职能,设置它的值为其他
<end-do>
insert into sys_capability_level(capability_id,capability_level_id,capability_level_name,capability_work_rate,enabled)
select d.capability_id,0,'其他',100,1 from sys_capability d where d.capability_id not in
(select distinct t.capability_id from sys_capability_level t) and d.is_leaf=1
</end-do>
-->
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_CAPABILITY})
</end-do>
</import>
<!-- #####################################资源池信息表的导入#####################################-->
<import id="sys_resourcePool" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" fkFilter="true" dist="deployData/system" files="资源池信息.xls$">
<pre-do>delete from SYS_RES_POOL_USER </pre-do>
<pre-do>delete from SYS_RES_POOL_CAPABILITY </pre-do>
<do>
<mainTable><![CDATA[(
@organNoSeq(resourcePoolID),@organNoSeq(poolCode),@myTrim(${资源池名称}),@systreePoolMap(${上级资源池}),"",
0,1,1,${描述},${创建人},@dateFormat(${创建日期}),${启用标志}
) into SYS_RES_POOL(
POOL_ID,POOL_CODE,POOL_NAME,PARENT_POOL_ID,NODE_ROUTE,
NODE_LEVEL,IS_LEAF,NODE_ROUTE_SELF,COMMENTS,UPDATE_BY,UPDATE_DATE,ENABLED
)]]> </mainTable>
<!-- 添加子表 -->
<subTables>
<subTable loop-column="对应职能" split="," as="职能">
<![CDATA[
(@mydict(keyParam:@myTrim(#{职能})),#{POOL_ID},1) into SYS_RES_POOL_CAPABILITY
(CAPABILITY_ID,POOL_ID,ENABLE)
]]>
</subTable>
</subTables>
</do>
<!-- 计算节点路径和节点级别-->
<end-do>@capabilityTreeRoute({tableName:SYS_RES_POOL,idField:POOL_ID,pidField:PARENT_POOL_ID})</end-do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_RES_POOL})
</end-do>
</import>
<!-- ########################### 部门信息表的导入#################################################### -->
<import id="sys_department" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" dist="deployData/system" files="部门信息.xls$">
<pre-do>delete from SYS_USER_INFO</pre-do>
<pre-do>delete from SYS_USER_LEVEL_PRICE</pre-do>
<pre-do>delete from SYS_DEPARTMENT_MASTER</pre-do>
<do>
<mainTable> <![CDATA[(${DepartmentID},${DepartmentCode},${SuperiorDepartmentID},
${DepartmentName},${simTitle},${type},${SequenceKey},${org_code},${Description},
${ModifyPerson},${ModifyDate},${contractcall},${contractfax},
${contractmail},@deptEnum(${delFlag}),"",0)
into SYS_DEPARTMENT_INFO (DEPT_ID,DEPT_CODE,PARENT_DEPT_ID,
NAME,SIMPLE_NAME,DEPT_TYPE,SHOW_ORDER,ORGAN_CODE,COMMENTS,
UPDATE_BY,UPDATE_DATE,TELEPHONE,FAX_CODE,EMAIL,ENABLED,NODE_ROUTE,NODE_LEVEL)
]]> </mainTable>
</do>
<!-- 更改一级机构的父节点为负1 -->
<end-do>update SYS_DEPARTMENT_INFO set PARENT_DEPT_ID=-1 where DEPT_ID=1</end-do>
<!-- 计算节点路径和节点级别-->
<end-do>@DeptTreeRoute({tableName:SYS_DEPARTMENT_INFO,idField:DEPT_ID,pidField:PARENT_DEPT_ID})</end-do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_DEPARTMENT_INFO})
</end-do>
<!--更改部门的级别 -->
<end-do>
update SYS_DEPARTMENT_INFO d set d.dept_type=3 where d.parent_dept_id in(1,28)
</end-do>
<end-do>
update SYS_DEPARTMENT_INFO d set d.dept_type=2 where d.parent_dept_id=6
</end-do>
<end-do>
update SYS_DEPARTMENT_INFO d set d.dept_type=4 where d.parent_dept_id=-1
</end-do>
<end-do>
update SYS_DEPARTMENT_INFO d set d.dept_type=1 where d.dept_id in(6,28)
</end-do>
</import>
<!-- ####################################资源级别报价的导入############################## 注:其中有些部门ID 在部门信息表中找不到对应的部门ID 会报错-->
<import id="sys_userleavePrice" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" fkFilter="true" dist="deployData/system" files="资源级别报价.xls$">
<pre-do>delete from SYS_USER_INFO</pre-do>
<do>
<mainTable> <![CDATA[(${id},${departmentId},${level},${pay},@deptEnum(${is_delete}))
into SYS_USER_LEVEL_PRICE (LEVEL_ID,DEPT_ID,APTITUDE_LEVEL,PRICE_VALUE,ENABLED)
]]> </mainTable>
</do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_USER_LEVEL_PRICE})
</end-do>
</import>
<!-- ####################################### 人力资源信息的导入###########${level} :LEVEL_ID################################################ -->
<import id="sys_userInfo" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" fkFilter="true" dist="deployData/system" files="资源信息.xls$">
<pre-do>
delete from SYS_RES_POOL_USER
</pre-do>
<do>
<mainTable> <![CDATA[
(
${UserID},${EmployeeCode},${UserName},${level},${LoginName},
${priceType},@SexEnum(${Gender}),
${Description},${Email},
${PhoneNumber}, ${AttachDepartmentID},${useDeptId},@MobileSubStr(${celltelephone}),
${utmost},${person_code},
${ModifyPerson}, ${ModifyDate} , ${startdate},
${enddate},@deptEnum(${delFlag}),${pmslogin})
into SYS_USER_INFO (
USER_ID, USER_CODE,NAME,LEVEL_ID,ENGLISH_NAME,
PRICE_TYPE, SEX,
COMMENTS, EMAIL,
TELEPHONE,DEPT_ID,WORK_DEPT_ID, MOBILE_NO,
MAX_DAY_WORK_HOURS, IDENTITY_ID,
UPDATE_BY, UPDATE_DATE,INDUTY_DATE,
OUTDUTY_DATE , ENABLED, PMS_ID)
]]> </mainTable>
</do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_USER_INFO})
</end-do>
<!--更改级别ID -->
<end-do>
update sys_user_info d set d.level_id=
(select t.aptitude_level from SYS_USER_LEVEL_PRICE t where t.level_id=d.level_id)
</end-do>
<!--更改sag表的enabled标志 -->
<end-do>
update sag_user t set t.enabled=
(select d.enabled from sys_user_info d where d.user_id=t.user_id)
</end-do>
</import>
<!-- #####################################资源池用户信息表的导入#####################################-->
<import id="poolUserInfo" datasource="pias" clear="true" active="true" startRow="2" endRow="836" titleRow="1" fkFilter="true" dist="deployData/system" files="资源池人员用户信息.xls$">
<do>
<mainTable> <![CDATA[(
@organNoSeq(poolUserID),${用户ID},@myPoolId(keyParam:@myTrim(${所属资源池})),1,@myCapdict(keyParam:@myTrim(${等级})),100,1)
into SYS_RES_POOL_USER (
ID,USER_ID,POOL_ID,CAPABILITY_ID,
CAPABILITY_LEVEL_ID,RATE,ENABLED
)]]> </mainTable>
</do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_RES_POOL_USER})
</end-do>
<end-do>
update SYS_RES_POOL_USER t set t.capability_id=
(select t1.CAPABILITY_ID from SYS_RES_POOL_CAPABILITY t1 where t1.pool_id=t.pool_id)
</end-do>
<!--更改未明确的人的职能级别为0
<end-do>
update SYS_RES_POOL_USER sss set sss.capability_level_id=16 where sss.capability_id in(17,18,56)
</end-do>
-->
<!--更改不在职的状态 -->
<end-do>
update SYS_RES_POOL_USER sss
set sss.enabled=
(select t.enabled from sag_user t where t.user_id=sss.user_id)
</end-do>
</import>
<!-- #####################################资源池经理表的导入#####################################-->
<import id="resPoolMaster" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" dist="deployData/system" files="资源池经理.xls$">
<do>
<mainTable> <![CDATA[(
${POOL_ID},${MASTER},${ENABLED})
into SYS_RES_POOL_MASTER (
POOL_ID,MASTER,ENABLED
)]]> </mainTable>
</do>
</import>
<!-- #####################################部门负责人表的导入#####################################-->
<import id="deptMaster" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" dist="deployData/system" files="部门负责人.xls$">
<do>
<mainTable> <![CDATA[(
${DepartmentID},${UserID},${ModifyPerson},@dateFormat(${ModifyDate}) )
into SYS_DEPARTMENT_MASTER (
DEPT_ID,USER_ID,CREATE_BY,CREATE_DATE
)]]> </mainTable>
</do>
</import>
<!-- #####################################工作类型表的导入#####################################-->
<import id="workType" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" dist="deployData/system" files="项目主阶段对应工作类型.xls$">
<pre-do>
delete from SYS_PJ_RES_DISTRIBUTE
</pre-do>
<do>
<mainTable> <![CDATA[(
${WORK_TYPE},${WORK_TYPE_NAME})
into SYS_PROJECT_WORK_TYPE (
WORK_TYPE,WORK_TYPE_NAME
)]]> </mainTable>
</do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_PROJECT_WORK_TYPE})
</end-do>
</import>
<!-- #####################################参数表的导入#####################################-->
<import id="resDistribute" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" dist="deployData/system" files="项目资源分布参数.xls$">
<do>
<mainTable> <![CDATA[(
${BATCH_TEMPLATE_TYPE},${MAIN_PHASE},${WORK_ITEM_TYPE},${WORK_TYPE},${ROLER},${SUB_PHASE},${RATE},${IS_LOCK})
into SYS_PJ_RES_DISTRIBUTE (
BATCH_TEMPLATE_TYPE,MAIN_PHASE,WORK_ITEM_TYPE,WORK_TYPE,ROLER,SUB_PHASE,RATE,IS_LOCK
)]]> </mainTable>
</do>
</import>
<!-- #####################################应用系统表的导入#####################################-->
<import id="application" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" dist="deployData/system" files="应用系统.xls$">
<do>
<mainTable> <![CDATA[(
${APP_ID},${APP_CODE},${APP_NAME},${COMMENTS},${ENABLED},${DEPT_ID})
into SYS_APPLICATION (
APP_ID,APP_CODE,APP_NAME,COMMENTS,ENABLED,DEPT_ID
)]]> </mainTable>
</do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_APPLICATION})
</end-do>
</import>
<!-- #####################################日终事务表的导入#####################################-->
<import id="transLog" datasource="pias" clear="true" active="true" startRow="2" titleRow="1" dist="deployData/system" files="系统日志表.xls$">
<do>
<mainTable> <![CDATA[(
${TRANS_ID},${TRANS_CODE},${TRANS_NAME},${RUN_FREQUENCY},${COMMENTS},${ENABLED})
into SYS_DAILY_TRANSACTION (
TRANS_ID,TRANS_CODE,TRANS_NAME,RUN_FREQUENCY,COMMENTS,ENABLED
)]]> </mainTable>
</do>
<!--sequence维护到序列表 -->
<end-do>
@myTableSequence({keyName:SYS_DAILY_TRANSACTION})
</end-do>
<!--更改离职人员的状态 -->
<end-do>
update sys_user_info d set d.enabled=0
where d.user_id in
(1501,1511,1281,53,54,55,1667,180,1273,1255,1258,1260,1261,1272,1298,1337,1352,1380,1382,1425,1481,1500,
1468,1455,1457,229,1078,1281,1357,1478,1485,1526,1527,1528,1529,1530,1634)
</end-do>
<end-do>
update sag_user d set d.enabled=0
where d.user_id in
(1501,1511,1281,53,54,55,1667,180,1273,1255,1258,1260,1261,1272,1298,1337,1352,1380,1382,1425,1481,1500,
1468,1455,1457,229,1078,1281,1357,1478,1485,1526,1527,1528,1529,1530,1634)
</end-do>
</import>
</sagacity>
评论
我之前自己写过一个关于模版映射的组件,把excel导入和导出通过excel模版规范导出的样式,通过一个xml来校验格式,很想借鉴下你的做法,把这个组件继续完善。
如果可以希望提供份源码,非常感谢。
我的邮箱是xosadan@163.com;非常感谢
发表评论
-
sqltoy-orm 增删改和load操作介绍
2017-08-19 00:40 1174上一篇sqltoy-orm 最佳查询介绍:http://z ... -
讲述最值得你了解的sqltoy-orm最佳查询实践
2017-05-19 00:08 2786sqltoy-orm(https://github.c ... -
正式开源sqltoy-orm框架
2016-12-27 00:33 2167https://github.com/chenrenfe ... -
Sqltoy ORM框架之:分页查询(没错包含你所有所有能用到的关系型数据库分页)
2014-06-04 18:00 2653本来打算再过一阵子整体介绍一下个人的Sqlto ... -
写在SqlToy ORM开源之前
2013-07-05 02:01 0一直想将SqlToy ORM开源,却一直比较忙,没有时间对整个 ... -
睿智平台中超完整的日期处理工具类DateUtil
2011-01-20 16:43 1515很多地方都会用到Date日期处理,睿智平台当然也包括自己的da ... -
xtable功能介绍以及改进计划
2009-06-25 15:06 2419xtable是由陈仁飞(zhongxuchen)独自开发的js ... -
数据库动态查询最佳实现
2009-03-24 16:27 5753上次发表过这样的介绍,可能是我介绍的不够准确,太多人都没有搞明 ... -
数据库表SEQUENCE产生
2009-02-19 16:27 2104补充说明:目前这种模式已经非常不合理了,经过一系列项目数据库 ... -
动态数据源
2009-02-18 13:12 1669SAGACITY(睿智)框架中的部 ... -
开创性的陈氏数据库动态查询设计
2009-02-17 11:19 3795(新版增加了直接结果映 ...
相关推荐
基于Maxwell设计的经典280W 4025RPM高效率科尔摩根12极39槽TBM无框力矩电机:生产与学习双重应用案例,基于Maxwell设计的经典280W高转速科尔摩根TBM无框力矩电机:7615系列案例解析与应用实践,基于maxwwell设计的经典280W,4025RPM 内转子 科尔摩根 12极39槽 TBM无框力矩电机,7615系列。 该案例可用于生产,或者学习用,(157) ,maxwell设计; 280W; 4025RPM内转子; 科尔摩根; 12极39槽TBM无框力矩电机; 7615系列; 生产/学习用。,基于Maxwell设计,高功率280W 12极39槽TBM无框力矩电机:生产与学习双用途案例
基于碳交易的微网优化模型的Matlab设计与实现策略分析,基于碳交易的微网优化模型的Matlab设计与实现探讨,考虑碳交易的微网优化模型matlab ,考虑碳交易; 微网优化模型; MATLAB;,基于Matlab的碳交易微网优化模型研究
二级2025模拟试题(答案版)
OpenCV是一个功能强大的计算机视觉库,它提供了多种工具和算法来处理图像和视频数据。在C++中,OpenCV可以用于实现基础的人脸识别功能,包括从摄像头、图片和视频中识别人脸,以及通过PCA(主成分分析)提取图像轮廓。以下是对本资源大体的介绍: 1. 从摄像头中识别人脸:通过使用OpenCV的Haar特征分类器,我们可以实时从摄像头捕获的视频流中检测人脸。这个过程涉及到将视频帧转换为灰度图像,然后使用预训练的Haar级联分类器来识别人脸区域。 2. 从视频中识别出所有人脸和人眼:在视频流中,除了检测人脸,我们还可以进一步识别人眼。这通常涉及到使用额外的Haar级联分类器来定位人眼区域,从而实现对人脸特征的更细致分析。 3. 从图片中检测出人脸:对于静态图片,OpenCV同样能够检测人脸。通过加载图片,转换为灰度图,然后应用Haar级联分类器,我们可以在图片中标记出人脸的位置。 4. PCA提取图像轮廓:PCA是一种统计方法,用于分析和解释数据中的模式。在图像处理中,PCA可以用来提取图像的主要轮廓特征,这对于人脸识别技术中的面部特征提取尤
麻雀搜索算法(SSA)自适应t分布改进版:卓越性能与优化代码注释,适合深度学习。,自适应t分布改进麻雀搜索算法(TSSA)——卓越的学习样本,优化效果出众,麻雀搜索算法(SSA)改进——采用自适应t分布改进麻雀位置(TSSA),优化后明显要优于基础SSA(代码基本每一步都有注释,代码质量极高,非常适合学习) ,TSSA(自适应t分布麻雀位置算法);注释详尽;高质量代码;适合学习;算法改进结果优异;TSSA相比基础SSA。,自适应T分布优化麻雀搜索算法:代码详解与学习首选(TSSA改进版)
锂电池主动均衡Simulink仿真研究:多种均衡策略与电路架构的深度探讨,锂电池主动均衡与多种均衡策略的Simulink仿真研究:buckboost拓扑及多层次电路分析,锂电池主动均衡simulink仿真 四节电池 基于buckboost(升降压)拓扑 (还有传统电感均衡+开关电容均衡+双向反激均衡+双层准谐振均衡+环形均衡器+cuk+耦合电感)被动均衡电阻式均衡 、分层架构式均衡以及分层式电路均衡,多层次电路,充放电。 ,核心关键词: 锂电池; 主动均衡; Simulink仿真; 四节电池; BuckBoost拓扑; 传统电感均衡; 开关电容均衡; 双向反激均衡; 双层准谐振均衡; 环形均衡器; CUK均衡; 耦合电感均衡; 被动均衡; 电阻式均衡; 分层架构式均衡; 多层次电路; 充放电。,锂电池均衡策略研究:Simulink仿真下的多拓扑主动与被动均衡技术
S7-1500和分布式外围系统ET200MP模块数据
内置式永磁同步电机无位置传感器模型:基于滑膜观测器和MTPA技术的深度探究,内置式永磁同步电机基于滑膜观测器和MTPA的无位置传感器模型研究,基于滑膜观测器和MTPA的内置式永磁同步电机无位置传感器模型 ,基于滑膜观测器;MTPA;内置式永磁同步电机;无位置传感器模型,基于滑膜观测与MTPA算法的永磁同步电机无位置传感器模型
centos7操作系统下安装docker,及docker常用命令、在docker中运行nginx示例,包括 1.设置yum的仓库 2.安装 Docker Engine-Community 3.docker使用 4.查看docker进程是否启动成功 5.docker常用命令及nginx示例 6.常见问题
给曙光服务器安装windows2012r2时候找不到磁盘,问厂家工程师要的raid卡驱动,内含主流大多数品牌raid卡驱动
数学建模相关主题资源2
西门子四轴卧式加工中心后处理系统:828D至840D支持,四轴联动制造解决方案,图档处理与试看程序一应俱全。,西门子四轴卧加后处理系统:支持828D至840D系统,四轴联动高精度制造解决方案,西门子四轴卧加后处理,支持828D~840D系统,支持四轴联动,可制制,看清楚联系,可提供图档处理试看程序 ,核心关键词:西门子四轴卧加后处理; 828D~840D系统支持; 四轴联动; 制程; 联系; 图档处理试看程序。,西门子四轴卧加后处理程序,支持多种系统与四轴联动
MATLAB下基于列约束生成法CCG的两阶段鲁棒优化问题求解入门指南:算法验证与经典文献参考,MATLAB下基于列约束生成法CCG的两阶段鲁棒优化问题求解入门指南:算法验证与文献参考,MATLAB代码:基于列约束生成法CCG的两阶段问题求解 关键词:两阶段鲁棒 列约束生成法 CCG算法 参考文档:《Solving two-stage robust optimization problems using a column-and-constraint generation method》 仿真平台:MATLAB YALMIP+CPLEX 主要内容:代码构建了两阶段鲁棒优化模型,并用文档中的相对简单的算例,进行CCG算法的验证,此篇文献是CCG算法或者列约束生成算法的入门级文献,其经典程度不言而喻,几乎每个搞CCG的两阶段鲁棒的人都绕不过此篇文献 ,两阶段鲁棒;列约束生成法;CCG算法;MATLAB;YALMIP+CPLEX;入门级文献。,MATLAB代码实现:基于两阶段鲁棒与列约束生成法CCG的算法验证研究
“生热研究的全面解读:探究参数已配置的Comsol模型中的18650圆柱锂电池表现”,探究已配置参数的COMSOL模型下的锂电池生热现象:18650圆柱锂电池模拟分析,出一个18650圆柱锂电池comsol模型 参数已配置,生热研究 ,出模型; 18650圆柱锂电池; comsol模型; 参数配置; 生热研究,构建18650电池的COMSOL热研究模型
移动端多端运行的知识付费管理系统源码,TP6+Layui+MySQL后端支持,功能丰富,涵盖直播、点播、管理全功能及礼物互动,基于UniApp跨平台开发的移动端知识付费管理系统源码:多端互通、全功能齐备、后端采用TP6与PHP及Layui前端,搭载MySQL数据库与直播、点播、管理、礼物等功能的强大整合。,知识付费管理系统源码,移动端uniApp开发,app h5 小程序一套代码多端运行,后端php(tp6)+layui+MySQL,功能齐全,直播,点播,管理,礼物等等功能应有尽有 ,知识付费;管理系统源码;移动端uniApp开发;多端运行;后端php(tp6);layui;MySQL;直播点播;管理功能;礼物功能,知识付费管理平台:全功能多端运行系统源码(PHP+Layui+MySQL)
基于Python+Django+MySQL的个性化图书推荐系统:协同过滤推荐,智能部署,用户定制功能,基于Python+Django+MySQL的个性化图书推荐系统:协同过滤推荐,智能部署,用户定制功能,Python+Django+Mysql个性化图书推荐系统 图书在线推荐系统 基于用户、项目、内容的协同过滤推荐算法。 帮远程安装部署 一、项目简介 1、开发工具和实现技术 Python3.8,Django4,mysql8,navicat数据库管理工具,html页面,javascript脚本,jquery脚本,bootstrap前端框架,layer弹窗组件、webuploader文件上传组件等。 2、项目功能 前台用户包含:注册、登录、注销、浏览图书、搜索图书、信息修改、密码修改、兴趣喜好标签、图书评分、图书收藏、图书评论、热点推荐、个性化推荐图书等功能; 后台管理员包含:用户管理、图书管理、图书类型管理、评分管理、收藏管理、评论管理、兴趣喜好标签管理、权限管理等。 个性化推荐功能: 无论是否登录,在前台首页展示热点推荐(根据图书被收藏数量降序推荐)。 登录用户,在前台首页展示个性化推荐
STM32企业级锅炉控制器源码分享:真实项目经验,带注释完整源码助你快速掌握实战经验,STM32企业级锅炉控制器源码:真实项目经验,完整注释,助力初学者快速上手,stm32真实企业项目源码 项目要求与网上搜的那些开发板的例程完全不在一个级别,也不是那些凑合性质的项目可以比拟的。 项目是企业级产品的要求开发的,能够让初学者了解真实的企业项目是怎么样的,增加工作经验 企业真实项目网上稀缺,完整源码带注释,适合没有参与工作或者刚学stm32的增加工作经验, 这是一个锅炉的控制器,有流程图和程序协议的介绍。 ,stm32源码;企业级项目;工作经验;锅炉控制器;流程图;程序协议,基于STM32的真实企业级锅炉控制器项目源码
整车性能目标书:涵盖燃油车、混动车及纯电动车型的十六个性能模块目标定义模板与集成开发指南,整车性能目标书:涵盖燃油车、混动车及纯电动车型的十六个性能模块目标定义模板与集成开发指南,整车性能目标书,汽车性能目标书,十六个性能模块目标定义模板,包含燃油车、混动车型及纯电动车型。 对于整车性能的集成开发具有较高的参考价值 ,整车性能目标书;汽车性能目标书;性能模块目标定义模板;燃油车;混动车型;纯电动车型;集成开发;参考价值,《汽车性能模块化目标书:燃油车、混动车及纯电动车的集成开发参考》
SNMP协议测试工具,解压:000000
基于MATLAB与YALMIP的含分布式与储能的微网优化调度模型:精准采集与高效求解,利用MATLAB和YALMIP构建含分布式与储能的微网优化模型,实现精准调度与约束管理,微网优化调度matlab 采用matlab+yalmip编制含分布式和储能的微网优化模型,程序采用15分钟为采集节点,利用cplex求解,程序考虑发电机的启停约束,程序运行可靠 ,微网优化调度; MATLAB编程; YALMIP; 分布式储能; 优化模型; CPLX求解; 节点采集; 发电机约束。,Matlab下的微网优化调度模型:分布式储能协同Cplex求解程序