Flink_sql

一、指定查询 DataStream->Table

	   StreamExecutionEnvironment env = Utils.getEnvironment();
	   StreamTableEnvironment tableEnv = StreamTableEnvironment.create(env);
	   DataStreamSource<String> dataSource = env.socketTextStream("192.168.134.6", 9898);

        //zhansan 苹果 4.5 2
        SingleOutputStreamOperator<Tuple3<String, String, Double>> ds = dataSource.flatMap(new FlatMapFunction<String, Tuple3<String, String, Double>>() {
            @Override
            public void flatMap(String s, Collector<Tuple3<String, String, Double>> collector) throws Exception {
                String[] split = s.split("\\s");
                collector.collect(new Tuple3(split[0], split[1], Double.parseDouble(split[2]) * Double.parseDouble(split[3])));
            }
        });
        
      //带有注册表的 QL 查询 // 将 DataStream 注册为视图“订单”
      tableEnv.createTemporaryView("Orders", ds, $("user"), $("product"), $("amount"));
      // run a SQL query on the Table and retrieve the result as a new Table
      Table result2 = tableEnv.sqlQuery("SELECT user,product, amount FROM Orders ");

      DataStream<Row> tuple3DataStream = tableEnv.toAppendStream(result2, Row.class);
      tuple3DataStream.print();

二、查询相关

2.1 GroupBy

 //1、设置运行环境
        StreamExecutionEnvironment env = Utils.getEnvironment();
        StreamTableEnvironment tableEnv = StreamTableEnvironment.create(env);
        DataStreamSource<String> dataSource = env.socketTextStream("192.168.134.6", 9898);

        //zhansan 苹果 4.5 2
        SingleOutputStreamOperator<Tuple3<String, String, Double>> ds = dataSource.flatMap(new FlatMapFunction<String, Tuple3<String, String, Double>>() {
            @Override
            public void flatMap(String s, Collector<Tuple3<String, String, Double>> collector) throws Exception {
                String[] split = s.split("\\s");
                collector.collect(new Tuple3(split[0], split[1], Double.parseDouble(split[2]) * Double.parseDouble(split[3])));
            }
        });
        
        //带有注册表的 QL 查询 // 将 DataStream 注册为视图“订单”
        // zhansan 苹果 4.5 2   zhansan 苹果 4.5 2
        // 李四 香蕉 5 2
        tableEnv.createTemporaryView("Orders", ds, $("user"), $("product"), $("amount"));
        // run a SQL query on the Table and retrieve the result as a new Table
        Table result2 = tableEnv.sqlQuery(
                "  SELECT user,product,sum(amount) as amount FROM Orders " +
                "      GROUP BY user,product ");

        DataStream<Tuple2<Boolean, Row>> tuple3DataStream = tableEnv.toRetractStream(result2, Row.class);
        tuple3DataStream.print();

        env.execute("test_transform_job");

		//(true,李四,香蕉,10.0)
		 (true,zhansan,苹果,9.0)
		 (false,zhansan,苹果,9.0)
		 (true,zhansan,苹果,18.0)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值