小编Kar*_*lth的帖子

为什么这个简单的 select 语句需要引号?

为什么下面的说法

select * from expertrule where rule_id = '1';
Run Code Online (Sandbox Code Playgroud)

返回此错误

ORA-00904: "RULE_ID": invalid identifier
Run Code Online (Sandbox Code Playgroud)

尽管

select * from expertrule where "rule_id" = '1';
Run Code Online (Sandbox Code Playgroud)

作品!

表格的每一列(只有这个表格)也是如此。此特定表中的所有列都需要将其名称括起来。为什么?

  CREATE TABLE "TEST"."expertrule" 
   (    "rule_id" NUMBER(*,0), 
    "name" VARCHAR2(256 BYTE), 
    "description" VARCHAR2(256 BYTE), 
    "ruleaccess" VARCHAR2(4000 BYTE), 
    "ruledisable" VARCHAR2(4000 BYTE), 
    "userssn" VARCHAR2(256 BYTE), 
    "departmentid" VARCHAR2(256 BYTE), 
    "active" CHAR(1 BYTE)
   ) SEGMENT CREATION IMMEDIATE 
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
 NOCOMPRESS LOGGING
  STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS …
Run Code Online (Sandbox Code Playgroud)

oracle

1
推荐指数
1
解决办法
981
查看次数

标签 统计

oracle ×1