使用javascript访问kettle内部组件
使用javascript访问kettle内部组件 很少有ETL项目需求使用kettle标准步骤不能实现的。假设举例每条记录都需标记为来自那个数据库的信息,原数据库是通过DB连接设置的,那如何获取这些设置?(类型、主机、端口、数据库名称等) 在kettle中没有标准步骤可以实现
使用javascript访问kettle内部组件
很少有ETL项目需求使用kettle标准步骤不能实现的。假设举例每条记录都需标记为来自那个数据库的信息,原数据库是通过DB连接设置的,那如何获取这些设置?(类型、主机、端口、数据库名称等)
在kettle中没有标准步骤可以实现,幸运的是javascript步骤可以访问kettle内部组件并实现以上需求。
访问kettle内部组件是_step_变量,其被自动设置在每个javascript步骤中。它代表javascript步骤本身,步骤的getTransMeta()方法返回TransMeta对象,表示整个转换,TransMeta对象可以用来获取关于定义在转换中的数据库连接信息。正确的TransMeta对象通过findDatabase()方法获得,返回DatabaseMeta对象,其他提供了一组方法返回数据库连接的信息。
下面的代码获取名称为“SourceDB”数据库连接的一些信息。
// get db object
var db = _step_.getTransMeta().findDatabase("SourceDB");
// ask db object for information
var db_type = db.getDatabaseTypeDesc();
var db_host = db.getHostname();
var db_port = db.getDatabasePortNumberString();
var db_name = db.getDatabaseName();
var db_tblspace = db.getDataTablespace();
var db_idxspace = db.getIndexTablespace();
var db_user = db.getUsername();
var db_pass = db.getPassword();
var db_url = db.getURL();
var db_driver = db.getDriverClass();
需要提醒的是,kettle版本在不断更新,其内部组件在不同版本之间可能不同。因此在把访问kettle内部组件的代码升级到一个新的版本时,需要做全面的测试。
说了那么多,不如去下载示例代码,其写数据库连接信息到一个文本文件,在5.1版本测试。
希望大家一起交流讨论,你们的建议是我的动力。
上一篇: 将MySQL默认datadir修改为自己想要的路径
下一篇: php实现Mysql读写分离的代码举例
推荐阅读
-
函数内部声明变量的时候,一定要使用var命令。如果不用的话,你实际上声明了一个全局变量!闭包访问局部变量
-
android使用include调用内部组件的方法
-
使用双网卡同时访问内部网络和互联网
-
JavaScript分页组件使用方法详解
-
使用JavaScript 实现时间轴与动画效果的示例代码(前端组件化)
-
[Kettle] java代码组件使用教学 & Kettle5.4版本java代码组件bug
-
JavaScript的Ext JS框架中的GridPanel组件使用指南
-
编写组件,使用JavaScript更新UpdatePanel
-
10_Android中通过HttpUrlConnection访问网络,Handler和多线程使用,读取网络html代码并显示在界面上,ScrollView组件的使用_html/css_WEB-ITnose
-
使用 webpack2 和 NPM Scripts 进行 JavaScript 组件开发