presto 函数中使用子查询
我们已知 在sql中子查询可以配合 in 或者 exists 来使用,但是如何把子查询的结果传给函数呢?
场景:
我们有一个 省份表 数据如下:
id province
1 广东
2 福建
3 江西
有一个分隔符表 数据如下:
seperator
,
-
...
+
要达到的目标是:一条sql实现省份按不同的分隔符做拼接。
需要结果:
广东,福建,江西
广东-福建-江西
广东...福建...江西
广东+福建+江西
我们先一条sql查出省份的顺序:
select province from province_table;
我们的按分隔符拼接字符串用array_join sql:
select array_join(['广东','福建','江西'],seperator) from seperator_table;
但是我们不能直接把sql1作为array_join 的参数1传入,
原因是函数里面传如子查询,等价于传入 子查询查出来 第一行第一个数据。
所有我们借助 array_agg函数,该函数为聚合函数,可以把传如的结果都聚合为一个数组:
select array_agg(province) from province_table;
结果为:(结果为一行一列)
['广东','福建','江西']
于是,我们最后的实现方式就可以是:
select array_join((select array_agg(province) from province_table),seperator) from seperator_table;
达到了“把结果转为数组传给函数使用”的效果。
presto 函数中使用子查询的更多相关文章
- 在 SQL Server 数据库的 WHERE 语句中使用子查询
		
这是关于子查询语句的一系列文章中的第三篇.在这篇文章中我们将讨论WHERE语句中的子查询语句.其他的文章讨论了其他语句中的子查询语句. 本次课程中的所有例子都是基于Microsoft SQL Serv ...
 - [20180626]函数与标量子查询14.txt
		
[20180626]函数与标量子查询14.txt --//前面看http://www.cnblogs.com/kerrycode/p/9099507.html链接,里面提到: 通俗来将,当使用标量子查 ...
 - SQL Fundamentals: 子查询 || WHERE,HAVING,FROM,SELECT子句中使用子查询,WITH子句
		
SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...
 - 详细讲述MySQL中的子查询操作 (来自脚本之家)
		
继续做以下的前期准备工作: 新建一个测试数据库TestDB: ? 1 create database TestDB; 创建测试表table1和table2: ? 1 2 3 4 5 6 7 8 9 1 ...
 - 在update语句中使用子查询
		
在update 中的 where 子句中使用子查询: UPDATE mg_page_log as a SET page_num=1 WHERE id in( SELECT id from mg_ ...
 - 子查询。ANY三种用法。ALL两种用法。HAVING中使用子查询。SELECT中使用子查询。
		
子查询存在的意义是解决多表查询带来的性能问题. 子查询返回单行多列: ANY三种用法: ALL两种用法: HAVING中的子查询返回单行单列: SELECT中使用子查询:(了解就好,避免使用这种方法! ...
 - 在MySQL中使用子查询
		
子查询作为数据源 子查询生成的结果集包含行.列数据,因而非常适合将它与表一起包含在from子句的子查询里.例: SELECT d.dept_id, d.name, e_cnt.how_many num ...
 - mysql 在update中实现子查询的方式
		
当使用mysql条件更新时--最先让人想到的写法 UPDATE buyer SET is_seller=1 WHERE uid IN (SELECT uid FROM seller) 此语句是错误的, ...
 - update 中实现子查询
		
mysql 在update中实现子查询的方式 当使用mysql条件更新时--最先让人想到的写法 UPDATE buyer SET is_seller=1 WHERE uid IN (SELECT ...
 
随机推荐
- day07数据类型的相互转化,字符编码
			
复习 ''' 1.深浅拷贝 ls = [1, 'a', [10]] 值拷贝:直接赋值 ls1 = ls, ls中的任何值发生改变,ls1中的值都会随之改变 浅拷贝:通过copy()方法 ls2 = l ...
 - springBoot整合jpa
			
https://blog.csdn.net/qq_35180973/article/details/82316438 总体来讲只是在service调用dao的时候用接口代替dao继承CrudRepos ...
 - 纸小墨ink简洁主题story爱上你的故事
			
主题介绍 为纸小墨写的一款主题,该主题移植自Yumoe github地址:ink-theme-story Demo ink-theme-story 主题的一些食用说明 菜单 标题旁边有一个 · 字符, ...
 - 【Git】Git使用记录: 基于git ignore文件将remote上的文件untrack
			
话不多说直接上步骤: git bash直接干到你的code. 直接敲命令: git rm -r --cached . rm是remove 命令 -r将允许递归删除 -cached只会从索引中删除文件. ...
 - Linux mint 下开发设置
			
切换thinpad Home-Pgup End-Pgdn sudo vim ~/.Xmodmap keysym Prior = Home keysym Next = End 禁用鼠标中间粘帖功能 su ...
 - 彻底搞懂Gradle、Gradle Wrapper与Android Plugin for Gradle的区别和联系
			
首先用一段通俗易懂但是不是非常专业的话描述一下三者的概念.区别和联系. Gradle是个构建系统,能够简化你的编译.打包.测试过程.熟悉Java的同学,可以把Gradle类比成Maven. Gradl ...
 - php接口签名验证
			
在做一些api接口设计时候会遇到设置权限问题,比如我这个接口只有指定的用户才能访问. 很多时候api接口是属于无状态的,没办法获取session,就不能够用登录的机制去验证,那么 大概的思路是在请求包 ...
 - 进程部分(IPC机制及生产者消费者模型)和线程部分
			
进程部分 一:进程间通信IPC机制:由于进程之间的内存空间是相互隔离的,所以为了进程间的通信需要一个共享的内存空间, 但是共享带来的问题是数据在写的时候就不安全了,所以需要一种机制既有能共享的内存 空 ...
 - Python的几个爬虫代码整理(网易云、微信、淘宝、今日头条)
			
整理了一下网易云歌曲评论抓取.分析好友信息抓取.淘宝宝贝抓取.今日头条美图抓取的一些代码 抓取网易云评论 进入歌曲界面: http://music.163.com/#/song?id=45318582 ...
 - 关于AMD 、CMD、 commonjs的认识
			
首先什么是amd.cmd和commonjs.总的来说,这三个玩意就是js的模块规范. 但是,这三者有什么区别呢.... amd规范是应用于浏览器,如requireJS. commonjs规范应用与服务 ...