https://github.com/lets-mica/stream-ql
用 SQL 来描述 Stream API。可用 SQL 来实现数据处理逻辑,支持实时数据处理,支持聚合,分组,自定义函数等功能。让数据处理更简单。
https://github.com/lets-mica/stream-ql
java
Last synced: 5 months ago
JSON representation
用 SQL 来描述 Stream API。可用 SQL 来实现数据处理逻辑,支持实时数据处理,支持聚合,分组,自定义函数等功能。让数据处理更简单。
- Host: GitHub
- URL: https://github.com/lets-mica/stream-ql
- Owner: lets-mica
- License: apache-2.0
- Created: 2021-12-02T08:19:13.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2021-12-14T00:52:29.000Z (about 4 years ago)
- Last Synced: 2025-04-08T15:46:20.386Z (9 months ago)
- Topics: java
- Language: Java
- Size: 69.3 KB
- Stars: 2
- Watchers: 2
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# StreamQL

Stream + Druid Sql Parser = StreamQL
## 使用
```java
public static void main(String[] args) {
StreamQL.sql("select * from '/test/1'")
.build()
.execute((table) ->
getMessage().stream()
.filter(data -> data.getTopic().equals(table)))
.forEach(System.out::println);
}
private static List getMessage() {
List data = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Message message = new Message();
message.setId(i);
message.setTopic("/test/" + i);
message.setClientId("clientId" + i);
message.setTimestamp(System.currentTimeMillis());
data.add(message);
}
return data;
}
```
## 参考vs借鉴
重度参考 vs copy [reactor-ql](https://github.com/jetlinks/reactor-ql),reactor-ql 非常强大。