收藏本站
我的资料
   
查看手机网站
OA系统选型网
采购软件系统 选型  免费咨询平台
按系统领域分
  • OA协同系统 • 移动应用
    OA协同系统
    无纸化系统
    移动OA
    协同管理
    移动应用
    移动考勤
    移动报销
    移动营销
  • HR人力资源 • 合同管理
    HR人力资源
    人事管理
    薪酬管理
    考勤管理
    招聘培训管理
    合同管理
    合同管理
  • CRM客户管理 • 项目管理
    CRM客户管理
    客户管理
    销售管理
    在线CRM
    项目管理
    项目管理
  • ERP系统 • 财务系统
    ERP系统
    生产制造ERP
    商贸ERP
    云ERP
    通用ERP
    财务系统
    资金管理
    财务管理
    报表管理
    财税一体化
  • 文档管理 • 流程管理
    文档管理
    文档查询
    文档存储管理
    文档安全管理
    流程管理
    流程管理
  • 预算管理 • 资产管理
    预算管理
    费用预算
    全面预算
    资产管理
    固定资产
    资产使用管理
  • 进销存管理 • 生产制造
    进销存管理
    库存管理
    采购管理
    存货核算
    在线进销存
    生产制造
    设备管理
    生产管理
    产能管理
    生产计划
  • 系统集成 • 定制开发
    系统集成
    安防监控
    远程管理
    定制开发
  • 建站推广 • 订货系统• 其它
    建站推广
    网站建设
    SEO网络推广
    小程序
    订货系统
    分销商城
    新零售
    微信三级分销
    其他
    硬件设备
    其它

Ecology9.0泛微系统接口指南——数据源和计划任务OA接口

 二维码 143
发表时间:2020-05-18 11:28作者:oa系统网址:http://www.gxskm.com



一、数据源

ecology提供了许多系统扩展接口,开发人员可以通过这些接口操作不同的数据源。例如把ecology的数据同步到其他的系统中去,或把其他系统中的数据同步到ecology中来,本质上就是在两个数据源之间交换数据。定义数据源的方法很简单,只需要在ecology安装目录/WEB-INF/service/datasource.xml中声明一下就可以了。

<service-point id="local" interface="weaver.interfaces.datasource.DataSource">

        <invoke-factory>

            <construct class="weaver.interfaces.datasource.BaseDataSource">

                <set property="type" value="oracle"/>

                <set property="host" value="192.168.0.204"/>

                <set property="port" value="1521"/>

                <set property="dbname" value="weaver1"/>

                <set property="user" value="dcwork1"/>

                <set property="password" value="dcwork1"/>

<set property="minconn" value="5"/>

<set property="maxconn" value="10"/>

            </construct>

        </invoke-factory>

</service-point>

上面的声明定义了一个oracle数据源,我们可以在datasource.xml文件中定义多个数据源,只需按照上面的格式添加一段新的声明就可以了,仅仅需要改动红色标出来的部分。例如添加一个sql server 数据源:msds

<service-point id="msds" interface="weaver.interfaces.datasource.DataSource">

        <invoke-factory>

            <construct class="weaver.interfaces.datasource.BaseDataSource">

                <set property="type" value="sqlserver"/>

                <set property="host" value="192.168.0.38"/>

                <set property="port" value="1433"/>

                <set property="dbname" value="ecology"/>

                <set property="user" value="sa"/>

                <set property="password" value="ecology"/>

<set property="minconn" value="5"/>

<set property="maxconn" value="10"/>

            </construct>

        </invoke-factory>

</service-point>

说明:

type: 数据库类型。有效值为oracle、sqlserver、db2、mysql

host: 数据库主机名或ip

dbname: 数据库名

user:数据库账号

password: 数据库密码

minconn: 连接池最小连接数

maxconn: 连接池最大连接数



二、计划任务接口

作用:

客户开发人员可以利用计划任务接口定时执行一段自己定义的操作,比如在两个数据源之间交换数据。


Ecology提供两种计划任务接口:

1
IntervalJob接口,此接口每隔一段时间执行一次(自己定义间隔时间)

2
CronJob接口,此接口在指定的时间点执行(自己定义时间点)


定义计划任务的方法是在ecology安装目录/WEB-INF/service/schedule.xml中声明:

<service-point id="job1" interface="weaver.interfaces.schedule.IntervalJob">

        <invoke-factory>

            <construct class="weaver.interfaces.schedule.BaseIntervalJob">

   <set-service property="ds" service-id="local"/>

   <set property="second" value="60"/>

            </construct>

        </invoke-factory>

</service-point>

上面的声明定义了一个名为job1的IntervalJob,该接口中的方法execute()将会每60秒执行一次。同时把前面定义的local数据源注入到了接口中,这样的话就可以在execute()中读写local数据源。我们也可以注入两个数据源到接口中,这样就可以在两个数据源之间交换数据:

<service-point id="job2" interface="weaver.interfaces.schedule.IntervalJob">

        <invoke-factory>

            <construct class="weaver.interfaces.schedule.BaseIntervalJob">

   <set-service property="ds" service-id="local"/>

<set-service property="ds1" service-id="msds"/>

   <set property="second" value="60"/>

            </construct>

        </invoke-factory>

</service-point>


声明一个CronJob的方法和IntervalJob类似,在ecology安装目录/WEB-INF/service/schedule.xml中声明:

<service-point id="job3" interface="weaver.interfaces.schedule.CronJob">

        <invoke-factory>

            <construct class="weaver.interfaces.schedule.BaseCronJob">

   <set-service property="ds" service-id="local"/>

<set-service property="ds1" service-id="msds"/>

   <set property="cronExpr" value="0 44 12 ? * MON-FRI"/>

            </construct>

        </invoke-factory>

</service-point>

上面的声明定义了一个周一到周五12:44执行的计划任务。什么时候执行计划任务由cronExpr表达式决定。

一个cron表达式有至少6个有空格分隔的时间元素,按顺序依次为:

秒(0~59)

分钟(0~59)

小时(0~23)

天(月)(0~31,但是你需要考虑你月的天数)

月(0~11)

天(星期)(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)


0 0 10,14,16 * * ? 每天上午10点,下午2点,4点

0 0/30 9-17 * * ?   朝九晚五工作时间内每半小时

0 0 12 ? * WED 表示每个星期三中午12点

"0 0 12 * * ?" 每天中午12点触发

"0 15 10 ? * *" 每天上午10:15触发

"0 15 10 * * ?" 每天上午10:15触发

"0 * 14 * * ?" 在每天下午2点到下午2:59期间的每1分钟触发

"0 0/5 14 * * ?" 在每天下午2点到下午2:55期间的每5分钟触发

"0 0/5 14,18 * * " 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发

"0 0-5 14 * * ?" 在每天下午2点到下午2:05期间的每1分钟触发

"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44触发

"0 15 10 ? * MON-FRI" 周一至周五的上午10:15触发

"0 15 10 15 * ?" 每月15日上午10:15触发

"0 15 10 L * ?" 每月最后一日的上午10:15触发

"0 15 10 ? * 6L" 每月的最后一个星期五上午10:15触发

"0 15 10 ? * 6#3" 每月的第三个星期五上午10:15触发


有些子表达式能包含一些范围或列表

例如:子表达式(天(星期))可以为 “MON-FRI”,“MON,WED,FRI”,“MON-WED,SAT”

“*”字符代表所有可能的值

因此,“*”在子表达式(月)里表示每个月的含义,“*”在子表达式(天(星期))表示星期的每一天

“/”字符用来指定数值的增量

例如:在子表达式(分钟)里的“0/15”表示从第0分钟开始,每15分钟

         在子表达式(分钟)里的“3/20”表示从第3分钟开始,每20分钟(它和“3,23,43”)的含义一样



“?”字符仅被用于天(月)和天(星期)两个子表达式,表示不指定值

当2个子表达式其中之一被指定了值以后,为了避免冲突,需要将另一个子表达式的值设为“?”

注意,上文中的weaver.interfaces.schedule.BaseIntervalJobweaver.interfaces.schedule.BaseIntervalJob是ecology提供的默认接口实现,它们的execute()是空的,不做任何操作。客户开发人员如果要使用计划任务接口的话,必需继承weaver.interfaces.schedule.BaseIntervalJobweaver.interfaces.schedule.BaseIntervalJob,用自己的业务逻辑覆盖它们的execute().

举个简单的例子,我需要ecology系统每隔一小时统计一下系统人数并输出到控制台,步骤如下

1
编写自己的计划任务实现

import weaver.interfaces.schedule.BaseIntervalJob;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

/**

* IntervalJob示范代码,集成BaseIntervalJob,用自己的业务逻辑覆盖了execute()方法

*/

public class MyIntervalJob extends BaseIntervalJob {

    public void execute() {

        //从数据源中获取连接

        Connection conn = getDs().getConnection();

        try {

            //通过jdbc获取人数

            PreparedStatement s = conn.prepareStatement("select count(*) as amount from hrmresource");

            ResultSet rs = s.executeQuery();

            rs.next();

            String amount = rs.getString("amount");

            //输出到控制台

            System.out.println("人数:" + amount);

            //关闭记录集

            rs.close();

            //关闭statement

            s.close();

        } catch (Exception e) {

            getLog().error(e);

        } finally {

            try {

                //关闭连接

                conn.close();

            } catch (Exception e) {

                getLog().error(e);

            }

        }

    }

}

3
在schedule.xml中声明

<service-point id="job3" interface="weaver.interfaces.schedule.IntervalJob">

        <invoke-factory>

            <construct class="MyIntervalJob">

   <set-service property="ds" service-id="local"/>

   <set property="second" value="3600"/>

            </construct>

        </invoke-factory>

</service-point>

可以用类似的方法实现自己的cronJob,本文不再赘述。

广泛业务.png


入驻机构:    <商家如何入驻>
本网部分内容转载自其他媒体,目的在于传递更多信息,并不代表本网赞同其观点或证实其内容的真实性。不承担此类作品侵权行为的直接责任及连带责任。
系统软件选型
价格高、不适用,要它有何价值?
        详情咨询在线客服QQ1917067885
在线客服
 
 
 
 
 联系方式
邮箱:1917067885@qq.com
会员登录
登录
我的资料
我的收藏
留言
回到顶部