Newsletter

Oracle APEX: WWV_FLOW_FND_USER_FK-Verletzung beim Importieren von Workspaces

Ich bin jüngst im Rahmen eines APEX-Projekts auf ein Problem gestoßen, für das ich im Oracle Support Portal keinen einzigen Eintrag finden konnte – nach einigem Überlegen und Testen aber auf eine relativ einfache Lösung gekommen bin.
Ausgangslage

Das erste Arbeitspaket im Rahmen des Projektes ist fertig entwickelt und soll dem Kunden zur Abnahme in der dafür von diesem bereitgestellten Test-Umgebung deployed werden. Da es in dieser Umgebung keine APEX-Entwicklungs-Umgebung gibt, sind die Sourcen per SQLplus, PL/SQL-Developer oder mit ähnlichen Tools zu deployen.

Nach der fehlerfreien Erstellung von Schemas, Tabellen, Packages etc. folgt der Import des APEX-Workspaces; das aus APEX exportierte Script hierfür schaut sinngemäß wie folgt aus:

set define off verify off feedback off
whenever sqlerror exit sql.sqlcode rollback
——————————————————————————–
— ORACLE Application Express (APEX) export file
— You should run the script connected to SQL*Plus as the Oracle user
— APEX_050100 or as the owner (parsing schema) of the application.
— NOTE: Calls to apex_application_install override the defaults below.
——————————————————————————–
begin
wwv_flow_api.import_begin (
p_version_yyyy_mm_dd=>'[DATE]‘
,p_default_workspace_id=>276…332
);
end;
/
prompt WORKSPACE 276…332
— Workspace, User Group, User, and Team Development Export:
— Date and Time: [DATE_AN_TIME]
— Exported By: ADMIN
— Export Type: Workspace Export
— Version: 5.1.2.00.09
— Instance ID: 714…698
— Import:
— Using Instance Administration / Manage Workspaces
— or
— Using SQL*Plus as the Oracle user APEX_050100
 
begin
wwv_flow_api.set_security_group_id(p_security_group_id=>276…332);
end;
/
—————-
— W O R K S P A C E
— Creating a workspace will not create database schemas or objects.
— This API creates only the meta data for this APEX workspace
prompt Creating workspace LEHM…
begin
wwv_flow_fnd_user_api.create_company (
p_id => 276…354
,p_provisioning_company_id => 276…332
,p_short_name => ‚[SHORT_NAME]‘
,p_display_name => ‚[DISPLAY_NAME]‘
,p_first_schema_provisioned => ‚[SCHEMA_NAME]‘
,p_company_schemas => ‚[SCHEMA_NAMES]‘
,p_account_status => ‚ASSIGNED‘
,p_allow_plsql_editing => ‚Y‘
,p_allow_app_building_yn => ‚Y‘
,p_allow_packaged_app_ins_yn => ‚Y‘
,p_allow_sql_workshop_yn => ‚Y‘
,p_allow_websheet_dev_yn => ‚Y‘
,p_allow_team_development_yn => ‚Y‘
,p_allow_to_be_purged_yn => ‚Y‘
,p_allow_restful_services_yn => ‚Y‘
,p_source_identifier => ‚[IDENTIFIER]‘
,p_path_prefix => ‚[PATH_PREFIX]‘
,p_files_version => 1);
);
end;
/
—————-
— G R O U P S
prompt Creating Groups…
begin
wwv_flow_api.create_user_groups (
p_id => 927…937,
p_GROUP_NAME => ‚OAuth2 Client Developer‘,
p_SECURITY_GROUP_ID => [ID],
p_GROUP_DESC => ‚Users authorized to register OAuth2 Client Applications‘);
end;
/
begin
wwv_flow_api.create_user_groups (
p_id => 927…936,
p_GROUP_NAME => ‚RESTful Services‘,
p_SECURITY_GROUP_ID => [ID],
p_GROUP_DESC => ‚Users authorized to use RESTful Services with this workspace‘);
end;
/
begin
wwv_flow_api.create_user_groups (
p_id => 927…912,
p_GROUP_NAME => ‚SQL Developer‘,
p_SECURITY_GROUP_ID => [ID],
p_GROUP_DESC => ‚Users authorized to use SQL Developer with this workspace‘);
end;
/
prompt Creating group grants…
—————-
— U S E R S
— User repository for use with APEX cookie-based authentication.
prompt Creating Users…
begin
wwv_flow_fnd_user_api.create_fnd_user (
p_user_id => ‚276…332‘,
p_user_name => ‚ADMIN‘,
p_first_name => “,
p_last_name => “,
p_description => “,
p_email_address => ‚[MAIL_ADDRESS]‘,
p_web_password => ‚[PASSWORD_STRING]‘,
p_web_password_format => ‚[PASSWORD_FORMAT]‘,
p_group_ids => “,
p_developer_privs => ‚ADMIN:CREATE:DATA_LOADER:EDIT:HELP:MONITOR:SQL‘,
p_default_schema => ‚[SCHEMA_NAME]‘,
p_account_locked => ‚N‘,
p_account_expiry => to_date(‚[DATE_AND_TIME]‘,’YYYYMMDDHH24MI‘),
p_failed_access_attempts => 0,
p_change_password_on_first_use => ‚Y‘,
p_first_password_use_occurred => ‚Y‘,
p_allow_app_building_yn => ‚Y‘,
p_allow_sql_workshop_yn => ‚Y‘
p_allow_websheet_dev_yn => ‚Y‘,
p_allow_team_development_yn => ‚Y‘,
p_allow_access_to_schemas => “);
end;
/
[MORE_USER_CREATION_STEPS]
prompt Check Compatibility…
begin
— This date identifies the minimum version required to import this file.
wwv_flow_team_api.check_version(p_version_yyyy_mm_dd=>'[DATE]‘);
end;
/
 
begin wwv_flow.g_import_in_progress := true; wwv_flow.g_user := USER; end;
/
[SOME_EMPTY_ANONYMOUS_BLOCKS]
begin
wwv_flow_api.import_end(p_auto_install_sup_obj => nvl(wwv_flow_application_install.get_auto_install_sup_obj, false));
commit;
end;
/
set verify on feedback on define on
prompt …done
 

Das Problem

An der Stelle, wo der erste User-Account erstellt werden soll, schlägt die Script-Ausführung dann fehl:

ORA-02291: Integritäts-Constraint (APEX_050100.WWV_FLOW_FND_USER_FK) verletzt – übergeordneter Schlüssel nicht gefunden

ORA-06512: in „APEX_050100.WWV_FLOW_FND_USER_INT“, Zeile 2010

ORA-06512: in „APEX_050100.WWV_FLOW_FND_USER_API“, Zeile 328

ORA-06512: in Zeile 2

 

Eine Suche im Oracle Support Portal nach WWV_FLOW_FND_USER_FK liefert (heute am 14.01.2020) exakt Null Ergebnisse – es ist also Eigeninitiative gefragt.
Eine Web-Suche offenbart recht schnell, dass der genannte Foreign Key ein Verweis auf den Workspace ist – was einigermaßen überraschend ist, da der Abschnitt der Workspace-Erstellung aus dem Script mit PL/SQL procedure successfully completed erfolgreich durchgelaufen war.

Die Lösung

Auf die Lösung bin ich erst gestoßen als ich im PL/SQL-Developer jeden Schritt einzeln ausgeführt habe. Bereits nach dem ersten Block erkannte der Developer eine aktive offene Transaktion – dies ist an entsprechenden Icons zu erkennen.

Die nachfolgenden Schritte verursachten keinerlei Probleme – bis die erste User Group importiert werden sollte. Hier fiel dann auf, dass dem Developer zufolge die Transaktion verschwand. Und der nachfolgende Import von User Accounts schlug daraufhin mit der bereits beschriebenen Fehlermeldung fehl.

Als ich die User-Group-Erstellung ausließ, funktionierte auch der User-Account-Import wieder problemlos. 😊

Da die User Groups im Rahmen des genannten Projekts nicht weiter verwendet werden, ist die Lösung ausreichend: das Entfernen der Erstellung der User Groups aus dem Workspace-Erstellungs-Scripts.

Die Ursache

Die genaue Ursache lässt sich ohne den entschlüsselten Code des Packages WWV_FLOW_API nur schwer ermitteln – höchstwahrscheinlich fehlt in der Procedure CREATE_USER_GROUPS aber ein RAISE um einen auftretenden Fehler weiterzureichen…

DBConcepts

Weitere Beiträge

DBConcepts Adventpunsch

Am Dienstag, den 03.12 findet heuer unser allseits beliebter Adventpunsch statt. Dieses Jahr treffen wir uns wieder im Weihnachtsdorf im Alten AKH (Universitätscampus).Wir haben einen eigens für uns

DBConcepts

Newsletter abonnieren

Wir freuen uns, dass wir Ihr Interesse für den Newsletter geweckt haben! Mit dem Versand dieser Zustimmung erhalten Sie regelmäßig alle aktuellen Informationen!

Vielen Dank für Ihr Interesse an unserem Unternehmen. Derzeit suchen wir niemanden für diese Stelle. Aber wir sind immer an talentierten Menschen interessiert und freuen uns von Ihnen zu hören! Schicken Sie uns einfach Ihren Lebenslauf und eine kurze Nachricht und schreiben Sie an welcher Stelle Sie interessiert sind: recruitment@dbconcepts.com. Wir freuen usn von Ihnen zu hören!