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."字段"来引用。
如果输入法处于英文输入状态,则不需要加双引号。
本文来自博客园,作者:小陆斑比,转载请注明原文链接:https://www.cnblogs.com/bamlubi/p/9982308.html