找到 150 篇文章 适用于 DB2

DB2 对各种数据类型使用哪些默认值?

Mandalika
更新于 2020-09-14 14:21:06

969 次浏览

如果用户未为列提供任何值,DB2 提供了一种在其中插入默认值的机制。对于每种 DB2 数据类型,都有一个固定的默认值,该值将分配给列(在创建表期间使用“DEFAULT”参数定义),如果在插入期间未提供该值。下表给出了 CHAR、VARCHAR、TIMESTAMP 和 INTEGER 的 DB2 默认值。数据类型DB2 默认值CHAR空格Varchar长度为 0 的空字符串TIMESTAMP当前时间戳INTEGER零

DB2 表中的 NULL 检查和插入规则是什么?

Mandalika
更新于 2020-09-14 14:06:49

481 次浏览

DB2 中的 Null 定义为空。它是一个未知值。如果我们想在任何列中限制 NULL 值,则应在 CREATE TABLE 中使用“NOT NULL”参数定义该列。“NOT NULL”将强制用户为该列输入一个值。但是,如果我们不想为此列提供任何值,我们也可以放置一个“WITH DEFAULT”参数,该参数将允许 DB2 在用户未为“NOT NULL”列提供任何值的情况下放置默认值。例如,如果我们有一个列 INVOICE_ID ... 阅读更多

一个表引用另一个表的外部键的级联规则是什么?

Mandalika
更新于 2020-09-14 13:57:08

3K+ 次浏览

外键用于在子表(其中列定义为外键)和父表(其中子表的外键成为主键)之间建立引用约束。例如,如果我们有一个 ORDER 表,其中外键定义为 TRANSACTION_ID。此外键将引用 TRANSACTIONS 表的 TRANSACTION_ID 列。在此 TRANSACTIONS 表中,TRANSACTION_ID 将是主键。这里的父表是 TRANSACTIONS 表,而子表是 ORDERS 表。外键的级联规则规定,当任何条目... 阅读更多

DB2 表中备用键的定义和用法是什么?

Mandalika
更新于 2020-09-14 13:52:07

497 次浏览

DB2 表包含许多列,其值将在整个表中保持唯一。在这些多列中,只有一列被选为主键,其余键称为候选键。我们可以将任何候选键声明为备用键。这意味着此键的值不能取重复值,但是与主键不同,不会在备用键上构建主键索引。我们在使用 UNIQUE 关键字定义任何表时都可以定义备用键。例如,如果我们想将 TRANSACTION_ID 作为备用键,则 - 创建表 ... 阅读更多

SQLCA 中的 SQLWARN3 有什么作用?通过一个实际例子说明?

Mandalika
更新于 2020-09-14 13:40:22

231 次浏览

SQLCA 中的 SQLWARN3 字段用于检测结果列数大于 COBOL-DB2 程序查询中给出的主机变量数的情况。SQLWARN3 是一个 1 字节字段,当查询返回的列数与使用的主机变量数不匹配时,它包含值“W”。我们可以使用 IF 或 EVALUATE 语句查询 SQLWARN3 的状态,如下例所示A010-CHECK-ORDER。EXEC SQL 选择 ORDER_DATE, ORDER_TOTAL 进入 :ORDER-DATE, 来自 ORDERS ... 阅读更多

如何截断分配给主机变量时 DB2 列数据的截断陷阱

Mandalika
更新于 2020-09-14 11:45:06

172 次浏览

在某些情况下,不使用 DCLGEN 成员,并且在工作存储区部分显式地完成主机变量声明。但是,由于这些显式声明,存在人为错误的可能性。其中一个错误是声明不正确的 COBOL 等效主机变量的数据长度。例如,主机变量应该声明为 PIC X(24),但错误地声明为 PIC X(14)。在这种情况下,当数据从 DB2 传输到 COBOL 程序时,由于接收主机变量的长度较短,列数据可能会被截断。我们可以检测... 阅读更多

如果不包含 DCLGEN 成员,COBOL-DB2 程序将如何运行?

Mandalika
更新于 2020-09-14 11:42:21

2K+ 次浏览

DCLGEN 成员包含两组重要的数据。包含表中所有列定义的表结构。COBOL 等效数据类型中的主机变量声明。除非我们在工作存储区部分显式地给出主机变量声明,否则包含 DCLGEN 成员不是强制性的。但始终建议包含 DCLGEN 成员,因为它还包含表结构,预编译器可以使用该结构执行查询列验证。尽管查询列验证对于预编译器是可选的,但它可以在预编译阶段为我们提供可能的错误... 阅读更多

SQLCA 中的 SQLCODE 在 COBOL-DB2 程序中的用途和用法是什么

Mandalika
更新于 2020-09-14 11:24:41

2K+ 次浏览

SQLCA 的 SQLCODE 字段用于获取从 DB2 到 COBOL 程序的上次执行的 SQL 查询的返回码。以下是 SQLCODE 字段可以取的一系列返回码及其含义。SQLCODE = 0 → 查询成功执行,没有任何问题。SQLCODE > 0 → 执行查询时发出警告。SQLCODE < 0 → 执行查询时发生错误。下面是演示 SQLCODE 用法的示例段落。A010-CHECK-ORDER。EXEC SQL 选择 ORDER_DATE 进入 :ORDER-DATE, 来自 ORDERS ... 阅读更多

如果在 COBOL-DB2 程序中不包含 SQLCA,结果会怎样?

Mandalika
更新于 2020-09-14 11:18:22

1K+ 次浏览

SQLCA 有助于 DB2 和 COBOL-DB2 程序之间的通信。SQLCA 有多个字段,它们提供有关上次执行的 SQL 查询的不同信息。SQLCA 在 COBOL-DB2 程序中是强制性的。但是,如果我们不使用 INCLUDE 语句给出 SQLCA,则程序编译将失败,并且我们将在日志中获得以下错误 -“SQLCA 未定义为数据名称”

DB2 数据类型 CHAR、DATE、TIME 和 TIMESTAMP 的 COBOL 等效项是什么?

Mandalika
更新于 2020-09-14 11:15:06

2K+ 次浏览

DATE、TIME 和 TIMESTAMP DB2 数据类型分别占用 4、3 和 10 个字节。CHAR 数据类型占用的内存根据给定的大小占用。下表显示了 CHAR、DATE、TIME 和 TIMESTAMP 的等效 COBOL 数据类型。DB2 数据类型DB2 字节COBOL 等效项COBOL 字节CHAR(z)zPIC X(z)zDATE4PIC X(10)10TIME3PIC X(8)8TIMESTAMP10PIC X(26)26

广告