gpt4 book ai didi

HANA OData 创建过程 - 我的新 ID 在哪里?

转载 作者:行者123 更新时间:2023-12-02 03:27:40 24 4
gpt4 key购买 nike

在我的 UI5 应用中,我有一个项目列表。我通过弹出窗口创建了一个新项目(输入一些详细信息并单击“确定”)。使用我的新实体的 JSON 数据,然后我在我的 OData 模型上调用“创建”。 OData 实体(在我的 xsodata 服务中定义)使用存储过程创建数据库记录,并使用序列生成下一个 ID。到目前为止,一切都很好。记录已创建,我的成功回调已执行。但是,我现在需要的是在我的响应负载中包含新记录的 ID,但我无法获取它。这是运行创建的 JS 代码,带有成功/错误回调:

// Update the model and add our new forecast
this.getView().getModel().create('/Forecasts', oData, {
success : jQuery.proxy(function(mResponse) {
// nav to newly created Forecast
this.getRouter().navTo("forecast", {
forecastId: mResponse.ID, // EMPTY!
tab: "data"
}, false);
}, this),
error : jQuery.proxy(function(mResponse) {
this.showErrorAlert("Problem creating new forecast");
}, this)
});

mResponse.ID 始终为空。我想,这不应该。 ID 定义为实体预测中的键。

@Catalog.tableType: #ROW
entity forecast {
key ID: IdType;
NAME: NameType;
CREATED: UTCDateTime;
USER: UsernameType;
EFFECTIVE: LocalDate;
DAYS: Integer;
};

以及 xsodata 服务(删除了模式和 namespace 引用):

service {

// Forecasts
"<namesapce>.data::models.forecast" as "Forecasts"
create using "<namesapce>.procedures::createForecast";
}

这是执行插入的存储过程:

PROCEDURE "<schema>"."<namespace>.procedures::createForecast" ( 
IN intab "<schema>"."<namespace>.data::models.procedures.forecast",
OUT outtab "<schema>"."<namespace>.data::models.procedures.errors"
)
LANGUAGE SQLSCRIPT
SQL SECURITY INVOKER
AS
-- DEFAULT SCHEMA <schema>
-- READS SQL DATA AS
BEGIN
DECLARE lv_name string;
DECLARE lv_days integer;

SELECT NAME, DAYS INTO lv_name, lv_days FROM :intab;

-- Now validate and insert
IF :lv_name = '' THEN
outtab = SELECT 500 AS http_status_code,
'Empty Forecast name' AS error_message,
'The Forecast name cannot be empty' AS detail FROM dummy;
ELSEIF :lv_days = 0 THEN
outtab = SELECT 500 AS http_status_code,
'Empty Forecast days' AS error_message,
'The Forecast days cannot be empty' AS detail FROM dummy;
ELSE
-- Perform the INSERT
INSERT INTO "<namespace>.data::models.forecast"
VALUES ("<namespace>.data::forecast".NEXTVAL,
lv_name,
CURRENT_TIMESTAMP,
CURRENT_USER,
CURRENT_DATE,
lv_days);
END IF;
END;

如何将 NEXTVAL 值(现在为 CURRVAL)放入我的响应负载中,以便可以在模型的创建函数的成功回调中访问它?我尝试了多个表,但遇到了不断的问题。当然有一个简单的方法可以做到这一点?插入记录的键是最重要的。我不想在客户端创建 ID,因为它不准确 - 我需要它从 INSERT 返回。

最佳答案

如果成功,对 HANA Odata 服务的 POST 请求将在状态为 201 的响应中返回创建的对象的数据。因此,您可以从响应中获取新插入数据的 ID。

关于HANA OData 创建过程 - 我的新 ID 在哪里?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29481514/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com