SAS-数据集SQL水平合并

一、SQL水平合并基本语法

sql的合并有两步,step1:进行笛卡尔乘积运算,第一个表的每一行合并第二个表的每一行,即表a有3行,表b有3行,则合并后3*3=9行。笛卡尔过程包含源数据的所有列,相同列名会合并。Step2:根据需要在第一步的基础上进行数据的筛选。

分类包括:

内合并(inner join)

外合并(outer join):左连接(left join)、右连接(right join)、全连接(full join)

二、内合并

方法1:from +where

where one.x=two.x

列名不需要相同,one.x=two.y,但数据类型需要相同。

from:最多连接32张表。

方法2:from+inner on

用"table.column"选择需要保留的变量。若第一张表是主表,需保留第一张表的所有变量,可用"one.*"。

可以在select中进行变量重命名。

可以在from中进行表的重命名,as可加可不加,更名后可在其他语句中进行使用。

三、外合并

3.1 左连接

3.2 右连接

3.3 全连接

3.4 merge与sql的区别

与merge进行配对的逻辑不同,merge先按照by进行排序,然后从上到下进行匹配,保留符合匹配规则。sql的结果与merge结果不一致。

3.5 Coalesce

Coalesce:合并,既包括one的,也包括two的x。与merge结果一致。

四、复杂的sql语句示例

4.1 在select中进行运算


4.2 添加标签

4.3 Select嵌套

类似if条件句的判断

4.4 多表连接,多条件判定

4.5 一个proc sql select语句,实现多表连接

相关推荐
weixin_387002154 分钟前
漏洞修复学习之CVE-2024-10976漏洞复现
数据库·sql·学习·安全·postgresql
芒果要切13 分钟前
SQL笔试题(2)
数据库·sql
robin591133 分钟前
Linux-通过端口转发访问数据库
linux·数据库·adb
懒羊羊不懒@1 小时前
【数据库 | 基础】DDL语句以及数据类型
数据库
泷羽Sec-静安1 小时前
Less-9 GET-Blind-Time based-Single Quotes
服务器·前端·数据库·sql·web安全·less
李宥小哥2 小时前
结构型设计模式2
网络·数据库·设计模式
猫头虎2 小时前
永久免费白嫖多个域名,一键托管Cloudflare,免费申请SSL加密证书,轻松建站、搭建线路伪装
服务器·开发语言·网络·数据库·python·网络协议·ssl
真正的醒悟2 小时前
什么是安全设备组网
服务器·数据库·php
nvd113 小时前
使用Terraform创建私有Cloud SQL实例及连接测试
sql·云原生·terraform
小哈里3 小时前
【软考架构】2025H2系统架构设计师考试复习.jpg(软件架构、软件工程、数据库、Web开发、高项)
数据库·架构·系统架构·软件工程·后端开发