kettle 设置临时变量使用-默认当前日期
kettle 设置临时变量使用-默认当前日期
使用场景
kettle在同步数据中需要使用当前日期为字段,同步出入到数据库中,或者其他的默认变量;
解决方法
使用kettle中的【javaScript代码】组件进行变量声明,例如声明当前时间包含时分秒,还有删除表示默认字段。
系统当前时间
Date.prototype.Format = function (fmt) {
var o = {
"M+": this.getMonth() + 1, //月份
"d+": this.getDate(), //日
"H+": this.getHours(), //小时
"m+": this.getMinutes(), //分
"s+": this.getSeconds(), //秒
"q+": Math.floor((this.getMonth() + 3) / 3), //季度
"S": this.getMilliseconds() //毫秒
};
if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
for (var k in o)
if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
return fmt;
}
//当前时间
var currentDatetime = new Date().Format("yyyy-MM-dd HH:mm:ss");
//是否已删除(0:未删除,1:已删除)
var is_deleted = 0;
接下里就可以进行【插入/更新】中的条件使用,或者其他操作使用都可以。
如果你有更好的方式进行变量声明,请留言哦,我会回复你的o( ̄︶ ̄)o