YashanDB中包括两类标识符:

作为语法关键字,用于定界SQL语法树的位置;作为系统保留语法关键字将不能作为数据库对象的名称。
作为数据库对象的名称,用于表名、列名、别名等用途,但需满足下述命名规范。

命名规范

标识符作为名称时存在如下规则和约束:(不使用双引号时)

支持所有的大小写字母和数字,且大小写不敏感。
不能出现特殊字符'\0' ',' ' ' '+' '-' '*' '/' '|' '(' '%' ':' '?' '.' '\t' '\r' '\n' '=' '\' '!' '>' '<' ';' '&' '^' '"' '~' ''' '{' '}' '[' ']'等。
不能使用系统保留语法关键字作为名称(包括大小写)。
当在标识符前后使用双引号时:

不受上述约束限制,即名称内可以出现特殊字符,可以非字母开头,并可以使用系统保留语法关键字作为名称。
对大小写的处理需满足下表规则:(同时需满足双引号的通用规则)

image.png

使用示例

-- 符合约束的标识符作为名称,定义时使用双引号
CREATE TABLE "CREATE01" (c1 INT);             -- 按全大写定义名称
Succeed.
INSERT INTO Create01 VALUES(1);               -- 不加双引号引用时,不区分大小写
1 row affected.
INSERT INTO "Create01" VALUES(1);             -- 加双引号引用时,严格区分大小写
[1:12]YAS-02012 table or view does not exist
  
DROP TABLE Create01;
Succeed.
CREATE TABLE "CREATe01" (c1 INT);             -- 按非全大写定义名称时,引用名称时必须使用双引号,且严格区分大小写
Succeed.
INSERT INTO CREATE01 VALUES(1);
[1:12]YAS-02012 table or view does not exist
INSERT INTO "CREATE01" VALUES(1);
[1:12]YAS-02012 table or view does not exist
INSERT INTO "CREATe01" VALUES(1);
1 row affected.
  
-- 违反约束的标识符作为名称,定义和引用都必须使用双引号
CREATE TABLE "CREATE" (c1 INT);         -- 按全大写定义名称时,引用时严格区分大小写
Succeed.
INSERT INTO CREATE VALUES(1);
[1:12]YAS-04202 missing or invalid table name
INSERT INTO "CREATE" VALUES(1);
1 row affected.
INSERT INTO "Create" VALUES(1);
[1:12]YAS-02012 table or view does not exist
  
DROP TABLE "CREATE";
Succeed.
CREATE TABLE "Create" (c1 INT);         -- 按非全大写定义名称时,引用时严格区分大小写
Succeed.
INSERT INTO Create VALUES(1);
[1:12]YAS-04202 missing or invalid table name
INSERT INTO "CREATE" VALUES(1);
[1:12]YAS-02012 table or view does not exist
INSERT INTO "Create" VALUES(1);
1 row affected.

YashanDB
1 声望0 粉丝

崖山数据库系统YashanDB是深圳计算科学研究院自主设计研发的新型数据库管理系统,融入原创的有界计算、近似计算、并行可扩展和跨模融合计算理论,可满足金融、政企、能源等关键行业对高性能、高并发及高安全性的...


« 上一篇
YashanDB字面量
下一篇 »
YashanDB双引号