点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)您好, 我正在使用Node.j...
点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)您好, 我正在使用Node.j...
加入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层进行交互。
谢谢
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
一周热门 更多>