Go to ‘Manage SAP HANA Cloud‘ to check if the instance is running, if not, you can run it by pressing ‘Start’ from the menu which appears by clicking ‘More’ (the three dots in the last column of Actions)
The starting will take some time and when is done you can see the status ‘Running’ with green color.
For the instance HANA_B, open the Database Explorer, to create a table and insert some data.
CREATE SCHEMA MYDATA;
SET SCHEMA MYDATA;
CREATE COLUMN TABLE HOTEL (
HNO INTEGER NOT NULL,
NAME VARCHAR(50) NOT NULL,
ZIP VARCHAR(5),
ADDRESS VARCHAR(40) NOT NULL,
PRIMARY KEY (HNO)
);
INSERT INTO HOTEL VALUES (10, 'Long Island', '11788', '1499 Grove Street');
INSERT INTO HOTEL VALUES (30, 'Lake Michigan', '60601', '354 Oak Terrace');
INSERT INTO HOTEL VALUES (100, 'Beachside', '32018', '1980 34th St.');
INSERT INTO HOTEL VALUES (110, 'Atlantic', '33441', '111 78th St.');
INSERT INTO HOTEL VALUES (120, 'Calypso', '90804', '35 Broadway');
INSERT INTO HOTEL VALUES (130, 'Evening Star', '90029', '13 Beechwood Place');
INSERT INTO HOTEL VALUES (140, 'Steamboat Louis Armstrong', '70112', '788 Main St.');
Once the table is created, it should look like this:
CREATE USER MYUSER
PASSWORD <password>
NO FORCE_FIRST_PASSWORD_CHANGE
SET USERGROUP DEFAULT;
GRANT SELECT ON SCHEMA MYDATA TO MYUSER;
To test the user and the grant, add the database HANA_B in the Database explorer and log in with the user MYUSER,
the newly created database will be added to the list. Right-click on it and 'Open SQL Console'
then if the select on the table works, it means the user and the grant work.
SELECT * FROM MYDATA.HOTEL;
From the ‘SAP HANA Cloud ‘overview of the ‘SAP BTP Cockpit’ you can open ‘SAP HANA Cloud Central’ by clicking ‘Manage SAP HANA Cloud’ button in the right upper corner.
From ‘SAP HANA Cloud Central’ by clicking on ‘More’ button of your HANA instance, then ‘Manage Configuration’
then ‘Edit’ button in the right upper corner, you can edit the instance’s configuration and then under the ‘Connections’ tab you can change the ‘Allowed connections’ setting.
For this scenario, I want to allow access from HANA_A to HANA_B, which means to set ‘Allow specific IP addresses and IP ranges’ and then specify the IP address of HANA_A. The IP Address of one HANA instance you can check by coping the EndpointAnd in the command line type nslookup and paste the endpoint, taking out the port of the end, and you should see the answer of what the IP address should be. In the ‘Manage Configuration’ of HANA_B we can now specify the IP address of HANA_A using CIDR notation.
Open SAP HANA Cockpit of HANA_A and log in as DBADMINFirst navigate to the ‘Security and User Management’ section and then to ‘Certificate Store’
And then ‘Import’ and ‘Browse’ the file which you downloaded, you can see this is the DigiCert Global Root certificate, then add it to a personal security environment, called certificate collection. Next ‘Go to Certificate Collection’ (the blue button) and ‘Add Collection’ (the blue button), give any name you like and then add the DigiCert Global Root certificate to it edit the purpose of the certificate collection, it should be ‘REMOTE SOURCE’ and that's it.
From the SAP HANA Database Explorer of HANA_A go to ‘Catalog’ and then right click on ‘Remote Source’ and ‘Add Remote Source’
In this part, you will create a project and replication task in it, but before starting, let’s first log in to the cloud foundry from the SAP Business Application Studio of the account where the instance HANA_A is located. Once you set up the SAP Business Application Studio and created Dev space in it, the next step is to log in to the cloud foundry. Find the cloud foundry icon on the left side menu and then click login, copy the Endpoint of HANA_A (from SAP BTP Cockpit) and provide the username and password. After successful login, create a new project from template and choose SAP HANA Database Project. Choose any project name you want and proceed to the next steps:
CREATE USER DEVUSER PASSWORD Password1 NO
FORCE_FIRST_PASSWORD_CHANGE SET USERGROUP DEFAULT;
GRANT CATALOG READ TO DEVUSER WITH ADMIN OPTION;
GRANT CREATE SCHEMA TO DEVUSER WITH ADMIN OPTION;
GRANT CREATE REMOTE SOURCE TO DEVUSER WITH ADMIN OPTION;
In the SAP BTP Cockpit navigate to the Services/Instances and in the right upper corner next to the Create button, click the arrow down and then 'User-Provided Service Instance'Provide the instance name and specify the parameters in JSON format:
{
"user": "DEVUSER",
"password": "Password1",
"schema": "DEVUSER",
"tags": [
"hana"
]
}
Once you create the DEVUSER, log in with it and create Remote Source pointing to HANA_B
{
"grant-service":{
"object_owner":{
"global_object_privileges":[
{
"name":"HANA_B_REMOTE",
"type":"REMOTE SOURCE",
"privileges":[
"CREATE VIRTUAL TABLE",
"CREATE VIRTUAL FUNCTION",
"CREATE REMOTE SUBSCRIPTION",
"PROCESS REMOTE SUBSCRIPTION EXCEPTION",
"ALTER",
"DROP"
]
}
]
},
"application_user":{
"global_object_privileges":[
{
"name":"HANA_B_REMOTE",
"type":"REMOTE SOURCE",
"privileges":[
"CREATE VIRTUAL TABLE",
"CREATE VIRTUAL FUNCTION",
"CREATE REMOTE SUBSCRIPTION",
"PROCESS REMOTE SUBSCRIPTION EXCEPTION",
"ALTER",
"DROP"
]
}
]
}
}
}
Open the ‘Command Palette’and type >Create SAP HANA Database Artifact Next, connect to the remote source, then select the object that you want to replicate. First click on the + ‘Add Object’, and search for our object, select it and scroll down You can choose any prefixes for the source and target tables, and the replication mode. For this scenario please choose ‘Initial + realtime’ which will provide the initial load, but also refresh the data, any time change happened. Once this is done, you need to deploy this object. This actually is going to build a lot of different objects, if you check the table list in the HDI container you can see the source and the target tables. Before executing the replication task, you can see that the target table is empty, and the source table is full. To execute the replication task you can search in the procedure list, generate the CALL Statement and just call the procedure. With this, replicating is happening. If you go back now to the TARGET_HOTEL table, you can see the data now.
set schema MYDATA;
update HOTEL set ADDRESS = '77 Broadway' where HNO = 120;
select * from HOTEL order by HNO;
Now, without doing anything, if you go back and refresh TARGET_HOTEL you can see that the update is already there
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
User | Count |
---|---|
8 | |
5 | |
4 | |
3 | |
3 | |
3 | |
3 | |
3 | |
2 | |
2 |