Skip to main content

MDS: Update script - NOT RECOMMENDED

For my use only don't use this without understanding what you are doing.

I had a bunch of old MDS features in my menu which was causing our menu to collapse on login.

(The collapse feature was set to not persist so the users had no way of fixing this).


Instead of writing code or purging all settings from MDS for that page I decided on a data fix.

Forgive my sql skills this was a quick and dirty.

SCHEMA: ???_MDS
TABLE : MDS_ATTRIBUTES - this is where all the mds configuration is kept for each item and attribute.
TABLE : MDS_PATHS - this is where the file name for the resource you are looking for is kept. (ie page.jsff) you can also find the user in the path so you can do this for a specific user.

DECLARE
    v_content_id MDS_PATHS.PATH_CONTENTID%TYPE;
    v_col_seq MDS_ATTRIBUTES.ATT_COMP_SEQ%TYPE;

    CURSOR v_path_cursor IS
      SELECT pa.PATH_CONTENTID FROM MDS_PATHS pa WHERE pa.PATH_PARTITION_ID = 3 AND PA.PATH_TYPE = 'DOCUMENT' AND PATH_NAME like '%portalTemplate%';
     
BEGIN
    OPEN v_path_cursor;
    LOOP
        FETCH v_path_cursor INTO v_content_id;
        EXIT WHEN v_path_cursor%NOTFOUND;

        BEGIN
          SELECT ATT_COMP_SEQ into v_col_seq FROM MDS_ATTRIBUTES a WHERE a.att_contentID = v_content_id AND a.ATT_PARTITION_ID = 3 AND a.ATT_VALUE = 'collapsed';
          EXCEPTION
          WHEN no_data_found
          THEN v_col_seq := null;
        END;

        IF v_col_seq IS NOT NULL THEN
          UPDATE MDS_ATTRIBUTES SET ATT_VALUE = 'false'  WHERE att_contentID = v_content_id AND ATT_PARTITION_ID = 3 AND ATT_COMP_SEQ = v_col_seq AND ATT_LOCALNAME = 'value'  AND ATT_VALUE = 'true';
          dbms_output.put_line('updating:' || v_content_id || '-'  || v_col_seq || ' split to false');
        END IF;
       
     END LOOP;
     CLOSE v_path_cursor;
END;
/


COMMIT;

NOTE: Restart Portal servers.

Comments

Popular posts from this blog

MANIFEST.MF merge JDeveloper for an executable jar

Goto your project > properties. Then click on deployment in the menu. Edit or add a jar deployment profile. Fill in the details under jar options (select Include manifest and give it a main class name) Also remember that the merge functionality only works with a BLANK line at the end of the merge file. REALLY this caught me. My merge file contents: Class-Path: commons-codec-1.3.jar [...empty line here CRLF...]

OJDeploy: Documentation for the tool

Real DOCS:  http://docs.oracle.com/cd/E26098_01/user.1112/e17455/deploying_apps.htm#OJDUG645 OJDeploy Documentation if you run it from the command line - I keep looking for this so I though I would post it here so I remeber. Oracle JDeveloper Deploy 11.1.2.1.0.6081 Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved. Usage:   ojdeploy -profile <name> -workspace <jws> [ -project <name> ] [ <options> ]   ojdeploy -buildfile <ojbuild.xml> [ <options> ]   ojdeploy -buildfileschema Arguments:   -profile               the name of the Profile to deploy   -workspace      full path to the JDeveloper Workspace file(.jws)   -project              name of the JDeveloper Project within the .jws where the Profile can be...

JBO-25013: TooManyObjectsException

oracle.jbo.TooManyObjectsException: JBO-25013: Too many objects match the primary key oracle.jbo.Key[Key null ]. Ok so for you it may be trying to insert a duplicate record this should explain your problem (also check trigger they could be the cause.) NOTE: You can also try to create a new duplicate EO if you have a page with two VO's using the same EO. This could sort your problems. For me I needed to add a launch listener on my LOV and clear the cache of my vo. LOV <af:inputListOfValues id="NameId" popupTitle="#{bindings.Name.hints.label}" value="#{bindings.RolName1.inputValue}" label="#{bindings.RolName1.hints.label}" model="#{bindings.RolName1.listOfValuesModel}" required="#{bindings.RolName1.hints.mandatory}" columns="#{bindings.RolName1.hints.displayWidth}" shortDesc="#{bindings.RolName1.hints.tooltip}" launchPopupListener="#{backingBeanScope.backingBean.launchPop...