kattle java脚本示例,Kettle使用示例

本文介绍了Kettle作为开源ETL工具的使用,包括认识常用组件、通过Java脚本生成随机数并计算统计值的示例,以及数据仓库的构建过程。通过表输入、字段选择、排序、分组和插入更新等操作,展示了如何从数据源获取数据,计算平均分,并将结果存入目标数据库。最后,提供了Java调用Kettle的示例代码。
摘要由CSDN通过智能技术生成

Kettle是一个开源ETL工具,做数据仓库用Spoon。

工具:下载Spoon,解压即可用

1、认识常用组件:

表输入

插入\更新

数据同步

文本文件输出

更新

自动文档输出

表输出

列转行

增加常量

增加序列

排序记录

行转列

过滤记录

数据库连接

合并记录

排序合并

记录关联(笛卡尔输出)

记录集连接

分组

在内存中分组

2、第一个例子

生成 100 个随机数,随机数取值于[0,100)之间, 计算小于等于 50 的随机数个数和 大于50 的随机数个 数。 并把这两个统计数字放在数据库表的一行的两列中, 即输出的结果有一行,一行包括两列,每列是一个统 计值。

726e202887cc

1.生成随机数,0-1区间内

2.定义常量,100

3.计算,随机数乘以100,使得生成的数据在0~100区间内

这里后面有分支,默认是数据分发,这里要保证数据全部都流到两条支路去要选择复制分发模式,在计算器这个步骤上面右键,选择数据发送,复制发送模式

4.条件判断有几种方法,这里用的是根据java代码过滤记录

5.分组计算总条数,4步中结果为真进分组1,否则分组2,分组里面计算总条数

6.关联记录

7.输出

3、数据仓库

目标:数据仓库就是把别的业务组的表查出来, 再转换, 保存到我们这边创建的新的业务表中。后续再开发接口(http、webservice、dubbo等)给别的组调用。

3.1用户评价表中有各种评价得分,这里对经纪人的各种得分求平均分保存到bidb_brance中

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 Java 的 HttpClient 类来发送 HTTP 请求。下面是一个使用 HttpClient 发送 HTTP POST 请求的示例代码: ```java import java.io.BufferedReader; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; public class HttpPostExample { public static void main(String[] args) { try { // 创建 URL 对象 URL url = new URL("http://example.com/api/endpoint"); // 创建 HttpURLConnection 对象 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); // 设置请求方法为 POST conn.setRequestMethod("POST"); // 设置请求头部信息 conn.setRequestProperty("Content-Type", "application/json"); conn.setRequestProperty("User-Agent", "Mozilla/5.0"); // 启用输出流,发送请求体数据 conn.setDoOutput(true); // 构造请求体数据 String requestBody = "{\"key1\":\"value1\", \"key2\":\"value2\"}"; // 发送请求体数据 conn.getOutputStream().write(requestBody.getBytes()); // 获取响应码 int responseCode = conn.getResponseCode(); System.out.println("Response Code: " + responseCode); // 读取响应内容 BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream())); String inputLine; StringBuilder response = new StringBuilder(); while ((inputLine = in.readLine()) != null) { response.append(inputLine); } in.close(); // 打印响应内容 System.out.println("Response: " + response.toString()); } catch (Exception e) { e.printStackTrace(); } } } ``` 在上面的代码,你需要替换 `http://example.com/api/endpoint` 为你要发送请求的接口地址。同时,你可以根据接口要求构造请求体数据,并设置请求头部信息。 这只是一个简单的示例,你可以根据实际情况进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值