LEFT JOIN和INNER JOIN 以及 FOR ALL ENTRIES IN

【在写开发报表的时候,遇到多表取数,重温数据库里面的集中多表取数的方法。】
        在ABAP开发中,JOIN、LEFT JOIN、INNER JOIN以及FOR ALL ENTRIES IN是用于将两个或多个表中的数据结合起来的不同方法。以下是它们之间的主要区别和使用方法:

  • JOIN:

JOIN是一个通用的术语,用于描述连接操作。在ABAP中,JOIN通常指的是INNER JOIN。

*假设有两个表A和B,A表有列id和name,B表有列id和value。
SELECT a~id, a~name, b~value
FROM A AS a
JOIN B AS b ON a~id = b~id.
  • LEFT JOIN(或LEFT OUTER JOIN)

LEFT JOIN返回左表中的所有行,即使在右表中没有匹配的行。如果右表中没有匹配的行,那么结果中的右表列将包含NULL值。

SELECT a~id, a~name, b~value
FROM A AS a
LEFT JOIN B AS b ON a~id = b~id.
*如果里面有字段值为空的数据 也能查询出来
  • INNER JOIN:

INNER JOIN只返回两个表中匹配的行。如果某个表中的行在另一个表中没有匹配的行,那么这些行将不会出现在结果中。

SELECT a~id, a~name, b~value
FROM A AS a
INNER JOIN B AS b ON a~id = b~id.
*如果表中有id为空的数据就不会被一起取出来
  • FOR ALL ENTRIES IN:

FOR ALL ENTRIES IN是SAP ABAP中的一种特殊连接操作,用于将一个表与另一个表中的多个行进行连接,FOR ALL ENTRIES IN 是一种特殊的循环结构,用于优化对内表的查询。它通常用于将一个主数据表与一个或多个从数据表进行连接,这种循环结构会为主表的每一行创建一个查询,并将这些查询合并成一个单一的数据库请求,这样可以显著提高性能。

DATA: GT_OUT TYPE TABLE OF ZTABLE_OUT, " 假设这是主数据表GT_DETAIL TYPE TABLE OF ZTABLE_DETAIL. " 假设这是从数据表" 假设 GT_OUT 已经被填充了数据SELECT * FROM ZTABLE_DETAIL " 从数据表FOR ALL ENTRIES IN @GT_OUT " 对于 GT_OUT 中的每一行WHERE KEY_FIELD = GT_OUT-KEY_FIELD. " 根据主数据表中的 KEY_FIELD 字段进行查询INTO TABLE @GT_DETAIL
" 结果会被存储在 GT_DETAIL 中

使用 FOR ALL ENTRIES IN 时,需要注意以下几点:

  1. FOR ALL ENTRIES IN 只能用于内表(内部表),不能用于数据库表。
  2. 查询条件必须引用 FOR ALL ENTRIES IN 后面指定的内表的字段。
  3. 如果主数据表中的行数非常多,可能会导致性能问题,因为每个行都会生成一个查询。
  4. FOR ALL ENTRIES IN 中的查询条件应该是高效的,以避免性能瓶颈。

          JOIN、LEFT JOIN和INNER JOIN是SQL标准中的连接操作,而FOR ALL ENTRIES IN是SAP ABAP中的一种特殊连接操作,用于处理SAP特定的数据模型。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/58320.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

元戎启行嵌入式面试题及参考答案

介绍下 CAN 通信原理 控制器局域网(CAN)是一种串行通信协议,主要用于汽车、工业自动化等领域的电子控制单元(ECU)之间的通信。 其通信原理是基于多主站架构。在总线上,多个节点(设备)都可以主动发起通信。CAN 协议使用差分信号来传输数据,通过两条信号线 CAN_H 和 CAN…

变异凯撒(Crypto)

目录 解题思路 题目设计原理 总结 解题思路 从题目可以看出,这是凯撒密码,原理应该还是整体偏移,但是变异了。 凯撒密码只有字母的横移,而通过观察我们可知,加密密文包含大小写字母、特殊字符,于是猜想大…

光伏无人机踏勘,照亮光伏未来!

光伏电站选址地分散在各地,想要精准获取该地的地形特点与屋顶面积等信息,传统的人工踏勘耗时耗力且精度无法保证,难以满足现代光伏项目的规模快发发展需求。光伏无人机踏勘,照亮光伏未来! 在光伏无人机智能踏勘设计系统…

Nvidia突袭AI江湖!悄悄发布新模型,完爆OpenAI和Anthropic?

你以为Nvidia只会造芯片?太天真了!这家GPU巨头刚刚在AI语言模型领域上演了一出惊天逆袭,让OpenAI和Anthropic都措手不及。 没有轰轰烈烈的发布会,没有铺天盖地的宣传,Nvidia就这么静悄悄地在Hugging Face平台上扔出了一…

一. nginx学习笔记 又长又臭篇幅

目录 引言 Nginx 简介 Nginx 的特点和优势 适用场景 安装 Nginx 在 Windows 上安装 Nginx 在 Linux (CentOS)上安装 Nginx 基本配置 Nginx 配置文件结构 启动、停止和重载 Nginx 基本的服务器块配置 处理静态文件 设置文档根目录 配置 MIM…

Hive SQL中判断内容包含情况的全面指南

Hive SQL中判断内容包含情况的实用指南 在 Hive SQL 的数据处理与分析世界里,判断字段是否包含特定内容是一项非常重要的操作。今天,我将为大家详细介绍 Hive SQL 中实现这一功能的多种方法,并附上相应的表创建和数据插入语句。 一、准备工作 - 表创建与数据插入 首先,我…

es 数据清理delete_by_query

POST /索引名/_delete_by_query?conflictsproceed&scroll_size2000&wait_for_completionfalse&slices36 {"size": 2000, "query": {"bool": { "must": [{"terms": {"rule_id": [800007]}}]}} }slice…

SVN 提交操作

SVN 提交操作 SVN(Subversion)是一个开源的版本控制系统,用于多个人共同开发同一个项目,实现共享资源,实现最终集中式的管理。在SVN中,提交操作是将本地更改上传到服务器的过程。本文将详细介绍SVN提交操作…

go中Println和Printf的区别

Don’t worry , just coding! 内耗与overthinking只会削弱你的精力,虚度你的光阴,每天迈出一小步,回头时发现已经走了很远。 go中Println和Printf的区别 package mainimport ( "fmt" )//TIP To run your code, right-click the c…

Windows 部署非安装版Redis

1.下载Redis https://github.com/microsoftarchive/redis/releases 选择下载zip包,如Redis-x64-3.0.504.zip,并解压 2.启动非安装版redis服务 进入到redis目录,打开cmd 执行命令 redis-server.exe redis.windows.conf 3.登录redis客户端…

OpenGL入门003——使用Factory设计模式简化渲染流程

前面两节已经学会了如何使用opengl创建窗口并绘制三角形,我们可以看出有些步骤是固定的,而且都写在main.cpp,这一节我们将了解如何使用Factroy设计模型。将模型渲染逻辑封装在一个单独的类中,简化开发流程,且提高代码复…

CSP-S 2024 游记

最后一年的正式开幕。 Day -1 教练居然没有让我们提前一天回家休息,恼。 Day 0 上午随机刷了下前几年的题,顺便解开了长达2年的心结,感觉恍如隔世。 下午随机看了几道题。 大伙在讨论着T3T4包有简单题之类的话题云云,感觉要…

Android camera2

一、序言 为了对阶段性的知识积累、方便以后调查问题,特做此文档! 将以camera app 使用camera2 api进行分析。 (1)、打开相机 openCamera (2)、创建会话 createCaptureSession (3)、开始预览 setRepeatingRequest (4)、停止预览 stopRepeating (5)、关闭…

qt QColorDialog详解

1、概述 QColorDialog是Qt框架中的一个对话框类,专门用于让用户选择颜色。它提供了一个标准的颜色选择界面,其中包括基本的颜色选择器(如调色板和颜色轮)、自定义颜色输入区域以及预定义颜色列表。QColorDialog支持RGB、HSV和十六…

基于Python的自然语言处理系列(54):Neo4j DB QA Chain 实战

在本篇文章中,我们将演示如何利用LangChain框架和Neo4j图数据库来构建一个基于问答链(QA Chain)的查询系统。通过调用大语言模型(LLM),可以动态生成Cypher查询,从而简化数据库查询的流程。这种方法非常适合应用于知识图谱、推荐系统等需要灵活数据查询的场景。 一、准备…

# linux系统(如ubuntu)新创建的用户终端命令无颜色,用户名等显示灰色名字而不是绿色问题解决方法

linux系统(如ubuntu)新创建的用户终端命令无颜色,用户名等显示灰色名字而不是绿色问题解决方法 一、问题描述: 在Linux系统中(如ubuntu),如果新创建的用户终端命令无颜色,用户名等…

ASP.NET Core 路由规则 总结 mvc

资料 资料 路由服务 路由服务是在 Program.cs 中使用 builder.Services.AddRouting()注册的, 只是默认在 builder 之前已经注册过了,无需我们再次注册。 AddRouting()方法必须在 UseRouting()方法之前运行,它是路由的基础服务。 MapContro…

MFC,DLL界面库设计注意

这个错误是由于CShapeBase类的虚表(vtable)没有正确生成或导出。在生成DLL时,需要确保虚函数表正确地在DLL中定义并导出,否则编译器会无法找到所需的符号,从而引发LNK2001错误。 为了解决这个问题,可以尝试…

koa项目实战 == 实现注册登录鉴权

一. 项目的初始化 1 npm 初始化 npm init -y生成package.json文件: 记录项目的依赖 2 git 初始化 git init生成’.git’隐藏文件夹, git 的本地仓库 3 创建 ReadMe 文件 二. 搭建项目 1 安装 Koa 框架 npm install koa2 编写最基本的 app 创建src/main.js const Koa…

信息学科平台系统构建:Spring Boot框架深度解析

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示: 图4-1系统工作原理…