根据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无关。您的问题是关于标识符,而不是数据。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)