概述
日萌社
人工智能AI:Keras PyTorch MXNet TensorFlow PaddlePaddle 深度学习实战(不定时更新)
大数据组件使用 总文章
- Impala 操作/读写 Kudu,使用druid连接池
- Kudu 原理、API使用、代码
- Kudu Java API 条件查询
- spark读取kudu表导出数据为parquet文件(spark kudu parquet)
- kudu 导入/导出 数据
- Kudu 分页查询的两种方式
- Kudu 创建主键
链接:https://pan.baidu.com/s/1jRbq0pVgDsf7ILTZsJjaAw
提取码:0kri
<!-- https://mvnrepository.com/artifact/org.apache.kudu/kudu-client -->
<dependency>
<groupId>org.apache.kudu</groupId>
<artifactId>kudu-client</artifactId>
<version>1.9.0</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.kudu</groupId>
<artifactId>kudu-spark2_2.11</artifactId>
<version>1.7.0</version>
</dependency>
package src.main.sample;
import org.apache.kudu.ColumnSchema;
import org.apache.kudu.Schema;
import org.apache.kudu.client.*;
import java.util.ArrayList;
import java.util.List;
public class SelectKuduData2
{
private static String tableName = "event_wos_p1";
//private static KuduClient client = new KuduClient.KuduClientBuilder("IP,IP,IP").defaultAdminOperationTimeoutMs(60000).build();
// 获取需要查询数据的列
private static List<String> projectColumns = new ArrayList<String>();
private static KuduTable table;
private static KuduScanner.KuduScannerBuilder builder;
private static KuduScanner scanner;
private static KuduPredicate predicate1;
private static KuduPredicate predicate2;
public static void main(String[] args) throws KuduException
{
try
{
//select 查询字段名
projectColumns.add("user_id"); //字段名
projectColumns.add("day");
table = client.openTable(tableName);
// 简单的读取 newScannerBuilder(查询表) setProjectedColumnNames(指定输出列) build()开始扫描
// KuduScanner scanner = client.newScannerBuilder(table).setProjectedColumnNames(projectColumns).build();
builder = client.newScannerBuilder(table).setProjectedColumnNames(projectColumns);
/**
* 设置搜索的条件 where 条件过滤字段名
* 如果不设置,则全表扫描
*/
//下面的条件过滤 where user_id = xxx and day = xxx;
long userID = 7232560922086310458L;
int Day = 17889;
//比较方法ComparisonOp:GREATER、GREATER_EQUAL、EQUAL、LESS、LESS_EQUAL
predicate1 = predicate1.newComparisonPredicate(table.getSchema().getColumn("user_id"),
KuduPredicate.ComparisonOp.EQUAL, userID);
predicate2 = predicate2.newComparisonPredicate(table.getSchema().getColumn("day"),
KuduPredicate.ComparisonOp.EQUAL, Day);
builder.addPredicate(predicate1);
builder.addPredicate(predicate2);
// 开始扫描
scanner = builder.build();
while (scanner.hasMoreRows())
{
RowResultIterator results = scanner.nextRows();
/*
RowResultIterator.getNumRows()
获取此迭代器中的行数。如果您只想计算行数,那么调用这个函数并跳过其余的。
返回:此迭代器中的行数
如果查询不出数据则 RowResultIterator.getNumRows() 返回的是查询数据的行数,如果查询不出数据返回0
*/
// 每次从tablet中获取的数据的行数
int numRows = results.getNumRows();
System.out.println("numRows count is : " + numRows);
while (results.hasNext()) {
RowResult result = results.next();
long user_id = result.getLong(0);
int day = result.getInt(1);
System.out.println("user_id is : " + user_id + " === day: " + day );
}
System.out.println("--------------------------------------");
}
}
catch (Exception e)
{
e.printStackTrace();
}
finally
{
scanner.close();
client.close();
}
}
}
最后
以上就是傻傻烤鸡为你收集整理的Kudu Java API 条件查询日萌社大数据组件使用 总文章 的全部内容,希望文章能够帮你解决Kudu Java API 条件查询日萌社大数据组件使用 总文章 所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复