错误 PLS-00201:必须声明标识符 kurtwb



我正在执行一个PL/SQL程序,但我收到错误PLS-00201:必须声明标识符"KURTWB">

DECLARE
create_user dba_users%ROWTYPE;
model_id varchar2(20);
user_name varchar2(20);
BEGIN
model_id:=&model_id;
user_name:=&user_name;
Select * INTO create_user from dba_users where username=model_id;
EXECUTE IMMEDIATE 'create user user_name identified by password
user_name default tablespace create_user.default_tablespace
temporary tablespace create_user.temporary_tablespace profile
create_user.profile;';
END;
/

下面是我输入的值

Enter value for model_id: kurtwb
old   6: model_id:=&model_id;
new   6: model_id:=kurtwb;
Enter value for user_name: rohit
old   7: user_name:=&user_name;
new   7: user_name:=rohit;

以下是我收到的错误

ERROR at line 6:
ORA-06550: line 6, column 11:
PLS-00201: identifier 'KURTWB' must be declared
ORA-06550: line 6, column 1:
PL/SQL: Statement ignored
ORA-06550: line 7, column 12:
PLS-00201: identifier 'ROHIT' must be declared
ORA-06550: line 7, column 1:
PL/SQL: Statement ignored    

您已输入kurtwb作为名为&model_id的替换变量的值。
SQLPLus(或 Oracle-SQL-Developer'(在此行中替换此变量:

BEGIN
model_id:=&model_id;
....
....

输入的值kurtwb.替换后,代码如下所示:

BEGIN
model_id:=kurtwb;
....
....

由于kurtwb未在任何地方定义,因此会出现PLS-00201: identifier 'KURTWB' must be declared错误。


我猜你想kurtwb作为字符串存储在model_id变量中,在这种情况下,你必须使用撇号来代替变量:

BEGIN
model_id:='&model_id';
....
....

最新更新