使H2引用的名称和未引用的名称相同

使H2引用的名称和未引用的名称相同,第1张

使H2引用的名称和未引用的名称相同

根据SQL规范的要求,H2中的引号名称区分大小写。这意味着它将起作用:

CREATE TABLE "testquote" (dummy INT, "quotedDummy" INT); SELECt * FROM "testquote";

但这不会:

SELECt * FROM "TestQuote";SELECt * FROM "TESTQuote";SELECt * FROM "TESTQUOTE";

在H2中,不带引号的名称不区分大小写。它们通常会转换为大写字母(例如在Oracle和其他数据库中)。这意味着声明

CREATE TABLE test (dummy INT);SELECt * FROM test;

与…相同

CREATE TABLE "TEST" ("DUMMY" INT);SELECt * FROM "TEST";

因此,H2的行为与Oracle相同。这与其他数据库(例如MySQL和PostgreSQL)如何处理标识符名称有所不同。H2具有兼容性功能:如果附加

;DATAbase_TO_UPPER=FALSE
到数据库URL,则取消引号标识符不会转换为大写,这意味着它们也区分大小写。但是在创建数据库时以及每次使用数据库时都需要附加此内容(如果附加现有数据库的设置,则现有对象的标识符已转换为大写)。

顺便说一下,这与用于数据的功能UPPER无关。您的问题是关于标识符,而不是数据。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5675439.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存