我在 Cloudant 中有一个文档 ID 为的数据库_id
。
将此数据从 Cloudant 复制到 dashDB 后,我有 2 个要使用此_id
列加入的单独表。在运行 SQL 我尝试了以下,但这不会运行。我在这里想念什么?我是否需要将列名替换为_id
不带下划线的名称?
select m.title, m.year, g.value
from MOVIES m
inner join MOVIES_GENRE g on m._ID = g._ID;
TL;DR:正如@gmiley 指出的那样,问题是由_ID
列名引起的,它不是普通的标识符(参见下面的定义),因此需要在 SQL 语句中用双引号"_ID"
或单引号括起来。'_ID'
select m.title, m.year, g.value
from MOVIES m
inner join MOVIES_GENRE g on m."_ID" = g."_ID";
与普通标识符不同,带引号的标识符区分大小写("_id"
不等同于"_ID"
而title
等同于TITLE
)。如果您要"_id"
在语句中指定,则会引发错误,指示未找到该列。
由于您已经提到您已经使用Cloudant 仓储流程来填充您的 DashDB 表,因此可能值得一提的是,在模式发现期间生成 DDL 时,属性名称是大写的。
示例:具有此结构的 JSON 文档的内容
{
"_id": "000018723bdb4f2b06f830f676cfafd6",
"_rev": "1-91f98642f125315b929be5b5436530e7",
"date_received": "2016-12-04T17:46:47.090Z",
...
}
将映射到三列:
_ID
类型 VARCHAR(...)
_REV
类型VARCHAR(...)
DATE_RECEIVED
类型...希望这可以帮助!
来自DB2 SQL 参考:
普通标识符是一个大写字母后跟零个或多个字符,每个字符是一个大写字母、一个数字或下划线字符。请注意,在指定普通标识符时可以使用小写字母,但在处理时会转换为大写字母。普通标识符不应是保留字。
例子:
WKLYSAL
WKLY_SAL
定界标识符是由双引号括起来的一个或多个字符的序列。序列中的前导空白很重要。序列中的尾随空格并不重要,尽管它们与标识符一起存储。两个连续的引号用于表示分隔标识符内的一个引号。这样,标识符可以包含小写字母。
例子:
"WKLY_SAL"
"WKLY SAL"
"UNION"
"wkly_sal"