PL/SQL编写的SQL语句插入SqlPlus时,报错 PLS-00302

最近刚开始用PL/SQL,然后发现写SQL语句时,运行的时候,会对表中的字段报错。

好像是对字段的使用有问题

原来写的错误代码大概像这样

 1 DECLARE xuehao XSB.id% TYPE;
 2 BEGIN
 3   SELECT
 4     id INTO xuehao 
 5   FROM
 6     xsb 
 7   WHERE
 8     name = '小明';
 9   DBMS_OUTPUT.PUT_LINE(xuehao);
10 END;
11 /

然后就,报了好多错啊!!

这是用PL/SQL写的,感觉不咋地,所以我又换了Navicat Premium,再写的时候会有不同的提示

 1 DECLARE xuehao XSB."id"% TYPE;
 2 BEGIN
 3     SELECT
 4         XSB."id" INTO xuehao 
 5     FROM
 6         xsb 
 7     WHERE
 8         XSB."name"    = '小明';
 9     DBMS_OUTPUT.PUT_LINE(xuehao);
10 END;
11 /

然后,我们发现,这里的字段都有双引号!

这就Interesting了,具体是为什么呢?

其实,对于字段加不加双引号,区分了这个字段在创建时,是用中文输入还是英文输入的,也就是编码不一样。

简而言之

如果在创建这个字段的时候,输入法处于中文输入状态,则需要加双引号,使用Table."字段"来引用。

如果输入法处于英文输入状态,则不需要加双引号。

posted @ 2018-11-19 11:48  小陆斑比  阅读(1157)  评论(0编辑  收藏  举报