软件包@ sap/cds for Node.js

2020-08-17 13:30发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)您好, 我正在使用Node.j...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


您好,

我正在使用Node.js/Express在Cloud Platform(CF)上构建应用程序。 这个东西有一个/db模块,其中包含一个实体定义(books-model.cds)和/srv,它在server.js上运行一个node.js应用,该应用应该读取在db模块上声明的数据。

根据此文档软件包@ sap/cds应该可以使用以下语句帮助我做到这一点:

 cds.importEntities([
     {$ entity:" xsds.test.cds :: ds_test.e1"},
     {$ entity:" xsds.test.cds :: ds_test.e2",
       $ fields:{
           一个:{$ association:" xsds.test.cds :: ds_test.e2",
                $ viaBacklink:" b"}
       }
     }
 ], 打回来);
 函数回调(错误,实体){
     var E1 =实体[" xsds.test.cds :: ds_test.e1"];
     var E2 =实体[" xsds.test.cds :: ds_test.e2"];
    //...
 }
 

事实是,@ sap/cds模块v2.10似乎不认为它对此负责。 此版本仅处理.cds文件的构建和部署(到hdbcds等)。

在该模块的旧版本中,在进入npm存储库之前,它被称为" sap-cds",并且确实提供了此.importEntity方法。

有人知道 npm.sap.com ,甚至存在吗?

到目前为止,我已经可以使用@ sap/xsenv和@ sap/hdbext与数据库进行交互。

导入xsenv = require('@ sap/xsenv')import hdbext = require('@ sap/hdbext')
 const services = xsenv.getServices({hana:'plcockpit-hdi'})

 express.use('/',hdbext.middleware(services.hana))
 express.get('/',(req,res)=> {
         req.db.exec('SELECT * FROM \" com.acme :: MyLibrary.Books \"',函数(错误,行){
             res.json({
                 结果:JSON.stringify(rows [0])
             })
         })
     })
 

(代码是原始代码的简化版本)

尽管它可以工作,但我想知道是否还有更多的"高级" api与CDS层进行交互。

谢谢

10条回答
hongfeng1314
2020-08-17 13:54

Hi Onu,

我正在和你做同样的事情。 在使用HANA时,您可能希望将XSA与HDI概念结合使用。 这意味着当您部署数据库部件时,将创建一个HDI容器。 然后,您必须确保您的node.js模块需要数据库容器。 然后,Cloud Foundry环境将把hdi容器的连接设置注入到node.js模块环境变量中。 这是使用XSA进行的标准Cloud Foundry开发。 然后,您可以获得容器的生成的技术用户和密码,并在上面的示例中使用它们。 但是...在将应用程序部署到云平台时,这不能解决问题。

我们如何告诉CD使用连接的环境变量而不是package.json中的固定值? 我只是想弄清楚如何填充cds.connect函数的options参数。 如果未提供参数,似乎它将从package.json中获取它们。

希望您可以关注。

干杯

Tobi

一周热门 更多>