INSTALLATION DOCUMENTS BY RAVI

Sunday, April 19, 2020

Oracle Analytics Server Data Visualization Machine Learning Fails With 'Something Went Wrong' Using Insight Explain Feature or Data Flow


Oracle Analytics Server Data Visualization Machine Learning Fails With 'Something Went Wrong' Using Insight Explain Feature or Data Flow



Show Details 
Step |j| Execution failed. Status: FAILED. Message: [nQSError: 46240] Python Process exited with non 0 exit Code
[nQSError: 43224] The Dataflow "Address State Data Flow" failed during the execution.
[nQSError: 43204] Asynchronous Job Manager failed to execute the asynchronous job.

















Solution:
Login to the server
Using 'sudo' or as 'root' user, install the libgfortran package




































Restart OAS:
  • stop.sh
  • start.sh

SQL query to find top 50 tables by size

select top50.owner, top50.table_name, meg, a.num_rows
from dba_tables a,
   (Select * from (
SELECT
   owner, table_name, TRUNC(sum(bytes)/1024/1024) Meg
FROM
(SELECT segment_name table_name, owner, bytes
 FROM dba_segments
 WHERE segment_type like 'TABLE%'
 UNION ALL
 SELECT i.table_name, i.owner, s.bytes
 FROM dba_indexes i, dba_segments s
 WHERE s.segment_name = i.index_name
 AND   s.owner = i.owner
 AND   s.segment_type like 'INDEX%'
 UNION ALL
 SELECT l.table_name, l.owner, s.bytes
 FROM dba_lobs l, dba_segments s
 WHERE s.segment_name = l.segment_name
 AND   s.owner = l.owner
 AND   s.segment_type = 'LOBSEGMENT'
 UNION ALL
 SELECT l.table_name, l.owner, s.bytes
 FROM dba_lobs l, dba_segments s
 WHERE s.segment_name = l.index_name
 AND   s.owner = l.owner
 AND   s.segment_type = 'LOBINDEX')
GROUP BY table_name, owner
HAVING SUM(bytes)/1024/1024 > 10  /* Ignore small tables */
ORDER BY SUM(bytes) desc
) where rownum < 51) top50
where top50.owner =a.owner
and top50.table_name = a.table_name
order by meg desc, num_rows desc;


Note: Change 50 to any other number of tables you want to find

Sunday, February 16, 2020

Loading xml file data to oracle table using python


Sample xml file (test.xml):

<?xml version="1.0"?>
<data>
    <customer name="Ravi" >
        <email>lravikumarvsp@gmail.com</email>
        <phone>9999999999</phone>
    </customer>
    <customer name="kumar" >
        <email>kumar@gmail.com</email>
    </customer>
    <customer name="lanke" >
        <email>lanke@gmail.com</email>
        <phone>8888888888</phone>
    </customer>
    <customer name="ravikumar" >
        <phone>7777777777</phone>
        <address>
            <street>kukatpally</street>
        </address>
    </customer>
</data>




Python script for parsing xml file data to data frame:

import pandas as pd
import xml.etree.cElementTree as et
#Reading Data from the xml file
parsedXML = et.parse( "test.xml" )                                                                         
dfcols = ['name','email','phone','street']                                                                                
df = pd.DataFrame(columns=dfcols)
def getvalueofnode( node ):
                return node.text if node is not None else None
for node in parsedXML.getroot():                                                                              
                name = node.attrib.get('name')
                email = node.find('email')
                phone = node.find('phone')
                street = node.find('address/street')
                df = df.append( pd.Series([name, getvalueofnode(email), getvalueofnode(phone), getvalueofnode(street)], index=dfcols) ,ignore_index=True)
print (df)                                                                                                                                  










Run the program as below:















Now create a table with column names in the data frame.

CREATE TABLE TEST 
   (                          "NAME" VARCHAR2(200 BYTE),
                               "EMAIL" VARCHAR2(200 BYTE),
                               "PHONE" VARCHAR2(200 BYTE),
                               "STREET" VARCHAR2(200 BYTE)
   )





















Python script for loading xml file to oracle table.

import pandas as pd
import cx_Oracle
import xml.etree.cElementTree as et
#Reading Data from the xml file
parsedXML = et.parse( "test.xml" )                                                                         
dfcols = ['name','email','phone','street']                                
df = pd.DataFrame(columns=dfcols)
def getvalueofnode( node ):
                               return node.text if node is not None else None
for node in parsedXML.getroot():                                                                               
                               name = node.attrib.get('name')
                               email = node.find('email')
                               phone = node.find('phone')
                               street = node.find('address/street')
                               df = df.append( pd.Series([name, getvalueofnode(email), getvalueofnode(phone), getvalueofnode(street)], index=dfcols) ,ignore_index=True)
print (df)                                                                                                                             
#Loading Data into the Database Table
host1 = '172.16.11.32'
port1 = '1521'
sid1 = 'srcdb'
schema1 = 'system'
pwd1 = 'Admin123'
sdsn = cx_Oracle.makedsn(host1, port1, service_name=sid1)    
connect=cx_Oracle.connect(schema1, pwd1, sdsn)                                                        
cursor=connect.cursor()
dataframe_list=df.values.tolist()                                                                                                              # convert the dataframe to list
sql='INSERT INTO TEST values (:1,:2,:3,:4)'
for index,elem in enumerate(dataframe_list):                                                   
                               cursor.execute(sql,dataframe_list[index]) 
                               connect.commit()                                                             













Run the script to load the data to oracle table now















Check the table for data






















Friday, January 17, 2020

Purge Oracle Analytics Cloud cache using curl command


Clearing cache for all databases:
Syntax:
curl -i -X DELETE -u joe@example.com:mypassword1 -H "X-ID-TENANT-NAME:myidentitydomain" https://mybicloudservice-myidentitydomain.analytics.us1.oraclecloud.com/bimodeler/api/v1/dbcache



Status : Failure -Test failed: ORA-01035: ORACLE only available to users with RESTRICTED SESSION privilege


Status: Failure -Test failed: ORA-01035: ORACLE only available to users with RESTRICTED SESSION privilege


Check the LOGINS status with the below SQL command.





















Connect to the database as an SYS user through command prompt and execute the below commands











Grant restricted session privilege to the required user as below.






Steps for restricting user to specific Work repository and Project in ODI


Steps for Restricting Visibility of Work Repositories for a specific user




















We have created a new work repository and When ODI developers connect to the ODI studio, they can edit the connection parameters.
In particular, they can manually select the Work Repository that they will connect to.
Repository access can be password protected, but for security reasons it is best to not even list repositories that users should not have access to it.

Select the ODI Security navigator



















Right-click on the CONNECT profile and select Duplicate Selection.
ODI creates a new profile called Copy of CONNECT



















Click on Yes


















Double-click on the new profile to rename it




































Expand the new profile to list all objects. At the bottom of the list of objects you will see an entry for Work Repositories.
Expand Work Repositories: you should now see the View method


















Double-click the View method and deselect the Generic Privilege check-box


















Save the changes to the view method


















Drag and drop the new profile on each developer’s name and select Yes when you are prompted to grant this profile to the user. You can then add any other profile in order to complete the privileges for that user.




































Once the new privilege has been assigned to the developers, you have to drag and drop the work repository name from Topology onto the user name in the Security module. To perform this operation, we have to dissociate the Security navigator from the other navigators.


















When we drag and drop the repository on the user, we are prompted to confirm that we want to grant this privilege to the user. select Yes. We then have to “activate” the privilege.
There are two possible options in that activation window, make sure to select the bigger check-mark as highlighted



































Drag and drop the project we want to grant for the user as below and click on Yes.


















Select “Allow all methods in all repositories” as activation method.


















Click on Yes


















Click on Save


















Now in the ODI Studio, only the allowed repository will be visible




































Login to Weblogic console
Go to services – Data Sources
Click on New – Generic Data Source






















Provide Name and JNDI Name and click on Next





















Provide the suitable driver and click on Next





















Provide the database details and click on Next




















Click on the Test configuration






















If the test got succeeded click on Next



















Select bia_odi_cluster and click on Finish and then click on Activate changes.



















Restart all the servers and services.

Login to ODI console master repository


















Click on Management


















Right-click on repository connections and click on create





















Provide the new work repository jndi details and click on next





































Now logout and login with the user to the specific repository





















Expand the Projects and check for the project we assigned.






















Start ODI Studio and login to the work repository where the projects we want to restrict and navigate to the Security view.


















Verify that all the object methods in the NG DESIGNER The profile has the "Generic Privilege" box unchecked.




































Like this uncheck Generic Privilege for all the view objects in Designer
For Project access restriction, affect the following Profiles to your User:
CONNECT, and NG DESIGNER


















From Designer, drag and drop the Projects to allocate to the User
When performing this operation, a window is displayed which prompts for method, and Work Repository selection.
Select all desired methods, and Work Repositories with the checkboxes




































Uncheck the methods we don’t want and click on save


















Login to the ODI console with the non-supervisor user to the work repository and check for the restricted project. Users should not see any project.




















Test Case1:
Executing a scenario as an admin user and checking for its session in odi_user

















Execute the scenario as below

















Provide agent and context and click on Execute Scenario


















Click on OK



















Logout and login as non-supervisor user now and check for the executed scenario session






































Test Case2:
Executing a scenario as odi_user and checking for its session



















Execute the scenario as below


















Provide agent and context and click on Execute Scenario

















Click on Ok




















Check for the executed session now




















  Opatch reports 'Cyclic Dependency Detected' error when patching ODI   Issue: When applying a Patch Set Update (PSU) to WebLogic Se...