2K+ 浏览量
DB2 中的 UNION 用于合并两个或多个 SELECT 语句。SELECT 语句可以作用于单个表或多个表。每个 SELECT 语句都会单独处理,并将它们的结果组合起来以给出最终结果行。UNION 语句会消除 SELECT 语句导致的重复行。如果我们想要保留重复的行,则可以使用 UNION ALL 语句。例如,如果我们想要提取 ORDERS 和 ORDERS_HIST 表中 ORDER_TOTAL 大于 1000 的所有 ORDER_ID,我们可以使用以下带有…阅读更多
151 浏览量
EXECUTE IMMEDIATE 和带有 PREPARE 的 EXECUTE 不能用于 SELECT 查询。对于 SELECT 查询,我们有一个固定列表 SELECT,其中要提取的列保持固定,并且不能更改。例如,如果我们想要选择 2020-08-14 下达的订单。然后我们可以使用如下所示的动态 SQL:示例 MOVE ‘SELECT ORDER_ID FROM ORDERS WHERE ORDER_DATE=?’ TO WS-SQL-QUERY EXEC SQL DECLARE ORDER-CUR CURSOR FOR SELQUERY END-EXEC EXEC SQL PREPARE SELQUERY FROM :WS-SQL-QUERY END-EXEC MOVE ‘14-08-2020’ TO WS-ORDER-DATE EXEC SQL OPEN ORDER-CUR USING :WS-ORDER-DATE END-EXEC PERFORM UNTIL SQLCODE = +100 …阅读更多
671 浏览量
EXECUTE IMMEDIATE 和 EXECUTE PREPARE 是动态 SQL 的形式。对于 EXECUTE immediate,我们可以在主机变量中给出 SQL 语句,并将此主机变量传递到 EXECUTE IMMEDIATE 中。下面的示例演示了这些形式。示例 01 WS-SQL-DECLARE 05 WS-SQL-LEN PIC S9(04) COMP。 05 WS-SQL-QUERY PIC X(70)。 MOVE +80 TO WS-SQL-LEN MOVE “UPDATE ORDERS SET ORDER_PAID = ‘YES’ WHERE ORDER_DATE = ‘14-08-2020’” TO WS-SQL-QUERY EXEC SQL EXECUTE IMMEDIATE :WS-SQL-DECLARE END-EXEC 对于 EXECUTE PREPARE,SQL 语句首先被准备,然后执行。我们可以使用这种形式的动态 SQL …阅读更多
1K+ 浏览量
静态 SQL 硬编码在 COBOL-DB2 程序中,并且 SQL 查询在程序执行期间不能更改。我们只能更改主机变量的值。在动态 SQL 的情况下,我们可以在运行时更改 COBOL-DB2 程序中的列、表和谓词。例如,根据当前日期,我们可以更新 ORDERS 或 ORDERS_HIST 表。可以使用包含 ORDERS 表或 ORDER_HIST 表的动态 SQL 来构建此查询。动态 SQL 的主要优点是其灵活性。我们可以根据业务逻辑添加列或更改表/谓词。在…阅读更多
122 浏览量
PLAN_TABLE 的 QBLOCK_TYPE 列主要提供有关查询类型的信息。它可以具有值为 CORSUB,这表示查询是相关子查询,而 NCOSUB 表示查询是非相关子查询。JOIN_TYPE 列指示查询中使用的连接类型。此列可以根据下表中的值进行取值。列值解释BLANK内部连接/无连接FFULL 外部连接L左外部连接R右外部连接
485 浏览量
DB2 中的 PLAN_TABLE 包含优化器从 EXPLAIN 语句中使用的访问路径的详细信息。此表提供了关于具有 DB2 SQL 语句的 PLAN 的大量信息。ACCESSTYPE 是 PLAN_TABLE 的列之一,它提供有关访问类型的详细信息。此列中可能存在的值及其解释如下所示。列值解释I索引访问R表空间扫描M多个索引扫描N谓词中存在的索引访问INDEXONLY 列可以取值为“Y”,这表示优化器只需要读取索引空间即可获取查询的数据。
285 浏览量
序列用于自动生成唯一 ID。我们可以在 DB2 表中将列定义为 SEQUENCE 类型。这将使 DB2 能够自动为插入到表中的每一行生成唯一的 ID。DB2 生成的自动 ID 在整个数据库中保持唯一。例如,SEQUENCE 的实际实现出现在为每个区域(北、东、西和南)分配了单独的 ORDERS 表的情况下,然后我们可以将 ORDER_ID 声明为 SEQUENCE。这将始终为 ORDER_ID 生成唯一值,而不管为北、东、…阅读更多
3K+ 浏览量
子查询是嵌套查询。当此子查询仅执行一次,并且此子查询的结果用于提取主查询中的数据时,此类型的子查询称为非相关子查询。另一方面,当子查询在每次执行时都引用主查询时,则该子查询称为相关子查询。例如,如果我们想从 ORDERS 表中提取所有 ORDER_TOTAL 大于总体平均值的订单,那么我们可以使用下面的非相关子查询。示例 SELECT ORDER_ID FROM ORDERS WHERE ORDER_TOTAL > (SELECT AVG(ORDER_TOTAL) FROM ORDERS) 有…阅读更多
5K+ 浏览量
问题:如何用 ORDERS 和 TRANSACTION DB2 表上的示例解释内部连接和外部连接。解决方案 JOIN 用于组合 DB2 中一个或多个表中的数据。主要有两种类型的 JOIN——内部连接和外部连接。它们之间的基本区别在于,内部连接是两个或多个表的交集,而外部连接是两个或多个表的并集。基本上,内部连接用于使用相等的列值组合多个表中的数据,而另一方面,在外部连接的情况下,如果…阅读更多
我们可以使用 ROLLBACK 语句撤销对 COBOL-DB2 程序所做的所有更改。但是,ROLLBACK 仅适用于尚未发出 COMMIT 的情况。如果我们使用了 COMMIT 语句,则 ROLLBACK 将撤销自上次 COMMIT 点后对 DB2 表所做的所有更改。例如,在 commit 语句之后,我们执行 UPDATE 语句来修改 ORDERS 表的 ORDER_PAID 列。之后,如果我们执行 ROLLBACK,则对 ORDERS 表的 UPDATE 将被撤销。示例 EXEC SQL COMMIT END-EXEC EXEC SQL UPDATE ORDERS SET ORDERS_PAID = ‘YES’ WHERE ORDER_DATE = :WS-CURRENT-DATE …阅读更多