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

ADF sort of generic screen for tables with the same structure

We have a couple (about a hundred) of tables with the same structure (Code, Description, Create Date, Update Date). So I wanted to do something simple so that I did not have to create all these screens 1) EO   I created the EO based on one of the tables I had that had the above columns. I then Added a transient attribute called table name to my EO based on a groovy expression. (the expression needs to change as I am reading web tier stuff from the model layer but I will fix this later) I then generated a java class for my EO. And added the following overriden method to my newly created java class. protected StringBuffer buildDMLStatement(int i, AttributeDefImpl[] attributeDefImpl,   AttributeDefImpl[] attributeDefImpl2, AttributeDefImpl[] attributeDefImpl3, boolean b) {   StringBuffer statement = super.buildDMLStatement(   i, attributeDefImpl, attributeDefImpl2, attributeDefImpl3, b); return new StringBuffer(StringUtils.replace(statement.to...

Util code

public static MethodExpression getMethodExpression( String expr, Class returnType, Class[] argTypes){ FacesContext fc = FacesContext.getCurrentInstance(); ELContext elctx = fc.getELContext(); ExpressionFactory elFactory = fc.getApplication().getExpressionFactory(); return elFactory.createMethodExpression( elctx, expr, returnType, argTypes); } public static javax.faces.el.MethodBinding getMethodBinding( String expr, Class[] argTypes){ FacesContext fc = FacesContext.getCurrentInstance(); ELContext elctx = fc.getELContext(); return fc.getApplication().createMethodBinding(expr, argTypes); } SetPropertyListener listener = new SetPropertyListener( ActionEvent.class.getName()); listener.setFrom(link.getRoute()); listener.setValueExpression("to", JSFUtils.getValueExpression("#{pageFlowScope.route}", String.class)); action.addActionListener(listener); AdfFacesContext.getCurrentInstance().getPageFlowScope() .put("route", lin...

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...]