This blog post gives details on how to create a JSON sample file for a data product in the Data Marketplace of SAP Data Warehouse Cloud via a database tool DBeaver. DBeaver is a SQL client software application that act as a general database engine for developers, SQL programmers, database administrators and analysts. The community version of DBeaver has advantages of free multi-platform database tool and supporting all popular databases such as MySQL, PostgreSQL, Oracle, SAP HANA etc.
How to download and install DBeaver: https://dbeaver.io/download/
The entire process of creating a sample data – from setup to HANA connection and a JSON file generation – including 5 steps with some additional explanations are following:
1. Setting up a database user in SAP Data Warehouse Cloud
- As a first step, you need to have a database user (DB) in SAP Data Warehouse Cloud in order to connect to HANA Cloud in DBeaver. In Space Management, you can create a DB user for data consumption and data ingestion. In this case, you only need to read the sample data views in DBeaver and then export it as a JSON file. As a result, the DB user setup can be done as following:
data:image/s3,"s3://crabby-images/a679b/a679b79736b7f633887e26318f78145fb9d7e99d" alt=""
- Database User Settings:
data:image/s3,"s3://crabby-images/a65fb/a65fbc252a1372384645f16a5d3982057f1f6f2d" alt=""
2. Create a SQL view which consists of a small amount of data (e.g filter on 1000 rows) of the data product and can present how the data product looks like.
- As sample data is just an exemplar of the actual data product so that the data consumer can get a glimpse of what contains in the data product, we only need to select the small amount (some rows) data from the original view which is used as a source for the data product. Create a SQL view as following:
SELECT * FROM “View_1” limit 999
data:image/s3,"s3://crabby-images/804f2/804f2b16214a08a152b166831c5003be76f075a2" alt=""
- Then validate SQL to check if there is any error in the SQL statement. Set expose for consumption so that it can be seen in DBeaver.
data:image/s3,"s3://crabby-images/18cfa/18cfa40fd4dfd3847cd70147d487e6069e369128" alt=""
- Then save and deploy the SQL view.
3. Connectivity with HANA Database in DBeaver
- After creating a DB user in SAP Data Warehouse Cloud, you need to connect to HANA Database using this user.
- New Database Connection (the + button on the top left) → HANA → Next
data:image/s3,"s3://crabby-images/60c5e/60c5e67a818fa9bf90030ba909e1e64c7670afad" alt=""
- The Connection Settings should be matched with the information of the DB user:
data:image/s3,"s3://crabby-images/610c6/610c685168d4c55c8f490a1e634042dda359144c" alt=""
- Click Finish to connect to the HANA Database.
4. Generate a JSON file for the sample data
- After connecting to HANA Cloud, go the connection you just created on the Tab Database Navigator.
- HANA Connection → Schemas → TEST → Views → View_1_Data_Sample → (right click) Export Data
data:image/s3,"s3://crabby-images/a4728/a472873015e17f0288c21c8a0b4274e56c6d78b1" alt=""
- The next steps should be done as following:
data:image/s3,"s3://crabby-images/5f8b6/5f8b604dc0db897ec08ba80d330880c055425d40" alt=""
data:image/s3,"s3://crabby-images/a2816/a28161f1c6fada92cb2be9b532902ffdae734c9f" alt=""
data:image/s3,"s3://crabby-images/9c4a9/9c4a959fe481cf89aafdd3f2b4ed66a5017b1231" alt=""
- Note: ‘Directory’ as where you choose to save the exported JSON file and ‘File name patterns’ as the name of the file.
data:image/s3,"s3://crabby-images/31ad4/31ad40d94121af86e31c85e3d251d9873be14d59" alt=""
data:image/s3,"s3://crabby-images/97672/976724f6de2792ab49383f4b8a3730b2747ca50c" alt=""
5. Format the JSON file
- In order to read the JSON file in the Data Marketplace, the exported JSON file should be formatted as following:
- Open the JSON file in the Text Edit, change the name of the value (in this example “View_1_Data_Sample”) into “data”. Then save.
data:image/s3,"s3://crabby-images/9e927/9e92714588581c3c9039665c514ae8f3d06b7567" alt=""
data:image/s3,"s3://crabby-images/53dd2/53dd22de002429b7efcd1afbaec1dca6ff6f6015" alt=""
After finishing the generation process, the JSON file is ready to be uploaded as the sample data for the data product in the Data Marketplace.