Showing posts with label SAP HANA Concepts. Show all posts
Showing posts with label SAP HANA Concepts. Show all posts

Thursday, 21 September 2017

SAP HANA: ODATA Service

·         An OData service exposes data stored in database tables or views as OData collections for analysis and display by client applications.
·         The client can be web browser, or SAPUI5 application or HTML5 application or any other application which supports OData.
·         An OData service for SAP HANA XS is defined in a text file with the file suffix .xsodata, for example, OdataSrvDef.xsodata.
·         The XSODATA services are great because they provide a large amount of functionality with minimal amounts of development effort.

XSOData Examples:

An OData service for SAP HANA XS is defined in a text file with the file suffix  .xsodata
The file must contain at least the entry
service {
}

Example:

Step 1: Open HANA Studio and Select “SAP HANA DEVELOPMENT” Perspective.

Step 2: Select “Repositories” tab on the left side. Right-click and select “Create Repository Workspace”. In the popup window, provide Workspace name. You may keep everything as default.

Step 3: Click on “Project Explorer” tab. Right-click and select “XS Project”. Provide a name for your project and click Next.
Step 4: Select the Workspace. Click on the browse button and select the package where you want to create the XS project.
Step 5: Leave everything else blank and click Finish.
Step 6: An XS project will be created as shown below. Note that it automatically creates 2 mandatory files - .xsapp and .xsaccess.


SAP HANA XS Application Descriptor (.xsapp):

            Each application that you want to develop and deploy on SAP HANA XS must have an application descriptor file.
The application-descriptor file has no name and no content; it only has the file extension “xsapp”, for example, .xsapp. For backward compatibility, content is allowed in the .xsapp file but ignored.
The .xsapp file marks the root folder of an SAP HANA XS application. All files in that package (and any sub-packages) are available to be called via URL.
If you remove this .xsapp file from your HANA XS project, then you will not be able to call the project components via URL.

Example:

If the package sap.test contains the file .xsapp, the application will be available under the URL
http://<host>:<port>/sap.test/

SAP HANA XS Application Access File (.xsaccess):

The application-access (.xsaccess) file enables you to specify who or what is authorized to access the content exposed by the application package and what content they are allowed to see.

The application-access file does not have a name before the dot (.); it only has the file extension .xsaccess. The contents of the .xsaccess file must be formatted according to JavaScript Object Notation (JSON) rules.

Step 7: Create XSOData file by right-clicking the Project and select NEW and select XSOData file. And provide details and click Finish.
Step 8: And enter the following script in a workspace.
service {
"KABIL_PRACTICE"."TH_EMP_NAMES" as "EMPLOYEE";}



Step 9: And activate it, by right click the workspace and select Team and select Activate.

Step 10: Finally, Again Right click and select Run As an XS Service. This will open the XSOData service in the default browser.


Step 11: Enter user id and password of HANA system. You will see the result as shown as below:



Example 2: For getting as a odata file


Follow all  the above steps from Step 1 to Step 7 and in Step 8 you just change the script like as shown below.
Step 8: And enter the following script in workspace.

service  {


   "KABIL_HC::EMPLOYEE_DETAILS"                  // Table or View 
   as "MyView"
   key ("EMP_ID");            }

And again, follow all the steps from Step 9 to Step 11.

Note:

We can get the result in json format by doing following things:

For example: if your URL is :

http://<host>:80<instance_number>/KABIL_XS_PROJECT/EMPLOYEE_DETAILS_VIEW.xsodata

Just add your alias name like:/<alias_name>/?$format=json.



Result:


SAP HANA: XS Engine

What is SAP HANA XS?

SAP HANA XS stands for SAP HANA Extended Application Services. Sometimes it is also referred as XS Engine or just XS. The main idea of SAP HANA XS is to embed a full-featured application server, web server, and development environment within the SAP HANA appliance itself.
It is used to implement Business Logic and web services on top of HANA tables and views.

SAP HANA XS 

            Please note that XS is not a completely separate technology that happens to be installed on the same hardware server as SAP HANA; XS is actually an extension of, and tightly integrated into, the SAP HANA Database.

Important points about SAP HANA XS:

·         XS is a Small footprint application server/web server.
·         It is the basis for an application development platform inside SAP HANA.
·         It simplifies the architecture and lowers the TCO (total cost of operation).
·         It provides easy access to SAP HANA database via HTTP-based consumption

Origin of SAP HANA XS:

XS Engine is a JavaScript application server based on the Mozilla SpiderMonkey engine. This is the same engine used in the Firefox Web browser.

Advantages of SAP HANA XS:

The major advantages of SAP HANA XS are simplicity, low cost of operation and performance.
·         SAP HANA XS minimize the architecture layers. We can create applications which run directly on HANA without additional external servers or system landscape.
·         This simplified architecture decreases the total cost of operation.
·         Furthermore, the performance is also better because of the closeness of the application and control flow logic to the database.
·         In case of separate application server data has to be moved back and forth between the application server and HANA database.
·         But in case of HANA XS, it’s only an inter-process communication which again enhances the performance.

Wednesday, 16 August 2017

What is Schema in SAP HANA?

A database schema is a way to logically group objects such as tables, views, stored procedures etc. Think of a schema as a container of objects.