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>

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值