如何在 SAP BTP 平台上重用另一个已经开发好的 service

Offer 驾到,掘友接招!我正在参与2022春招打卡活动,点击查看活动详情

假设我们的 SAP Business Technology Platform 平台上已经开发好了一个 products-service 项目:

我们希望在另一个 bookstore 项目里,重用 products-service 项目。

打开 products-service 项目,在 package.json 里找到其 name 的值:@sap/capire-products

创建一个 bookstore 项目:

mvn -B archetype:generate -DarchetypeArtifactId=cds-services-archetype -DarchetypeGroupId=com.sap.cds \

-DarchetypeVersion=1.17.0
-DgroupId=com.sap.cap -DartifactId=bookstore

使用 open workspace 的功能打开这个项目:

执行如下命令行,安装指向 products-service 项目的依赖:

npm install $(npm pack ../products-service -s)

成功安装完毕,现在在 bookstore 项目里,就能看到其依赖 products-service 的实现了:

npm pack 从 products-service 创建一个 tarball,然后直接将其用作书店应用程序中的依赖项。 有关 npm 包的更多信息:docs.npmjs.com/cli-command…

使用下面的命令行安装依赖:

npm install && npm dedupe

现在 bookstore 项目的 package.json 里,就能看到 products-service 项目的依赖了。

在 db 文件夹下新建一个 schema.cds 文件,维护 domain model:

在 srv 文件夹下创建一个 services.cds 文件:

在 db 文件夹下新建一个 data 文件夹,然后把 4 个 sample data 的 csv 文件放置进去。

使用命令行部署 domain model 到 sqlite:

cds deploy --to sqlite

自动生成了一个 sqlite.db 文件,该文件名维护在 package.json 文件里,文件位于项目根目录下:

修改项目里的 Application.yaml 文件,将数据库的位置指向刚刚运行的命令行 cds deploy --to sqlite 生成的 sqlite.db 文件。

第 11 行设置成 never 的原因是因为我们已经用命令行 cds deploy --to sqlite 对数据库进行了初始化操作。

修改 Business Application Studio 的 settings.json 文件,添加如下内容:

     "sqltools.connections": [
         {
             "name": "sqlite",
             "dialect": "SQLite",
             "database": "/home/user/projects/bookstore/sqlite.db"
         }
     ]
复制代码

选择 SQLTools

可以看到刚才通过 csv 文件插入的数据:

使用如下 url:

workspaces-ws-pdwk4-app1.us10.trial.applicationstudio.cloud.sap/odata/v4/Bo…

就能访问到之前通过 sap.capire.bookstore-Books.csv 插入到 SQLite 里的数据了:

猜你喜欢

转载自juejin.im/post/7079970821845811230