`
zhongxuchen
  • 浏览: 32472 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

excel-tools改进计划

阅读更多

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>

 

 

 

  • 大小: 20.8 KB
  • 大小: 17.9 KB
0
0
分享到:
评论
2 楼 xosadan 2012-05-10  
你好  excelToy这个工具我很有兴趣 但是看了你在googlecode发布的源码里面没有这个相关的源码 只有sagacity-core里面有源码,其他文件夹下都是空的,包括googlecode里面的exceltoy项目,里面源码也是空的。
我之前自己写过一个关于模版映射的组件,把excel导入和导出通过excel模版规范导出的样式,通过一个xml来校验格式,很想借鉴下你的做法,把这个组件继续完善。
如果可以希望提供份源码,非常感谢。
我的邮箱是xosadan@163.com;非常感谢
1 楼 crabboy 2010-09-05  
没有头尾啊 ,不知excel-tools是什么东东?

相关推荐

    JD central Tools-crx插件

    v1.1按类别将商品固定到商店JD Central Tools - 易于数据提取产品,价格,销售等级,审查简单数据提取工具,价格,价格,销售,评论该Chrome Extension允许您以可编辑的Excel格式将产品详细信息分开。现在您可以...

    Mat-ImageImportEditor:MatImageImportEditor-管理工具,用于支持www.michas-ausflugstipps.de后端的图像导入

    垫图像导入监视器 描述 这是为在后端上导入图像而创建的管理工具的子集。 ...2014年基于原始java + excel-tools的初始版本 需要 用于建筑 专家 IDE(我用eclipse构建了它) 使用 Java 具有html5-s

    HomePro Tools-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策...

    AsLine v4.0 CAD地形图切剖面辅助插件

    3、获取多段线的拐点坐标,并导出至Excel及txt。 升级日志 AsLine v3.0 to AsLine v4.0 ------------------------------------------- 1、改进:剖面线支持折线; 2、改进:剖面交点最多可支持10000个; 3、优化:...

    易语言程序免安装版下载

    支持“链接后动作(post_link_action)”(参见tools\link.ini中注释) 4. 重新整理所有官方支持库的静态库,有望彻底解决链接时可能出现的符号冲突 5. 全面取消静态编译中的人为功能限制(此前有最多5个支持库同时...

    Makro Tools-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策...

    BigC Tools-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策...

    Central Tools-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策...

    Lotus Tools-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策...

    Inwshop Tools - Product, Sales-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策h

    We Love Shopping Tools - Product, Sales-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策...

    Aliexpress Tools - Product, Sales-crx插件

    - 产品特征- 价格 - 销售价格和细节 - 产品网址 - 产品图片和规格- 顾客评价技术支援:我们很乐意倾听意见或意见来改进产品。请联系:mail.weloveshe@gmail.com开发人员:www.weloveshee.com.隐私政策...

    天涯论坛的EXCEL阅读器(用宏写的,适合上班族用)V1.3C

     1、该程序采用vba宏设计,所以EXCEL必须开启宏,相关操作:菜单项 Tools(工具) -&gt;Macro(宏) -&gt; Security(安全),Security level (安全等级)设置成 Low(低),确定后关闭EXCEL窗口,再重新启动EXCEL。  2、进入相应...

    助手工具为Instagram「Helper Tools for Instagram」-crx插件

    版本0.290 - 导入到Excel,更加改进了HTTP 429错误的处理,错误修正和改进,包括指示当承诺的追随者/追随者数量与实际返回的用户数量不一致的情况(可能会发生多个帐户连接的用户)。 版本0.280 - 错误修正,流程...

    Crypto_Tools:该存储库用于帮助人们编写和更新文件的工具

    Crypto_Tools 该存储库用于帮助人们编写和更新文件的工具。 这些工具已在MS Excel中创建,因此您可以根据需要轻松地查看/更新这些工具。 我将计算所得的字段保留为可见状态,以便您可以看到它们正在使用安全文件执行...

    H5智能内核-基于MVC架构的全新Zoomla!逐浪CMS2 x3.8发布

    扩展:/Tools/ 维护工具,增加对加密文本的维护功能 增加:内容管理、商品、商城新增二维码,后台一键分享更方便 修改:修改CMS密钥机制 修改:webup多文件上传组件,增加图片压缩功能 场景:增加相册功能,并扩展支持...

    asp.net知识库

    改进ADO.Net数据库访问方式 ASP.NET 2.0 绑定高级技巧 简单实用的DataSet更新数据库的类+总结 [ADO.NET]由数据库触发器引发的问题 为ASP.NET封装的SQL数据库访问类 DataTable.Select方法的性能问题 .NET 2.0里使用强...

    EdrawSoft Edraw Max 7.2.0.2467 流程图作图工具

    Edraw Max lets you create a wide range of diagrams using templates, shapes, and drawing tools while working in an intuitive and familiar Office-style environment. New Features • The UI is MS ...

    网管教程 从入门到精通软件篇.txt

    可用数据文件(能被Excel 97打开);Oracle 8.1.x表格空间文件 DBX:DataBearn图像;Microsoft Visual FoxPro表格文件 DCT:Microsoft Visual FoxPro数据库容器 DCU:Delphi编译单元文件 DCX:Microsoft Visual...

Global site tag (gtag.js) - Google Analytics