- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 OData V4.0 API,我正在努力思考如何正确创建实体。我正在使用这个 OData V4.0 reference service .
我的“天真”假设(基于大多数数据库的工作方式)是,当将实体发布到集合时,我会省略主键并让服务生成它并在响应中将其返回给我。
换句话说,当我发出以下请求时:
POST http://services.odata.org/Experimental/OData/(S(<SessionID>))/OData.svc/Products
Content-Type: application/json
{
"@odata.type": "ODataDemo.Product",
"Name": "Widget",
"Description": "A simple widget",
"ReleaseDate": "1991-01-01T00:00:00Z",
"DiscontinuedDate": null,
"Rating": 4,
"Price": 2.5
}
我期待状态码为 201 Created
的答复和一个 Location
标题类似 http://services.odata.org/Experimental/OData/(S(<SessionID>))/OData.svc/Products(11)
.
相反,我收到以下错误:
The serialized resource has a null value in key member 'ID'.
Null values are not supported in key members.
所以我想,也许我可以将其设置为任意值,服务将忽略它并发布自己的 ID。所以我尝试以下请求:
POST http://services.odata.org/Experimental/OData/(S(<SessionID>))/OData.svc/Products
Content-Type: application/json
{
"@odata.type": "ODataDemo.Product",
"ID": 0,
"Name": "Widget",
"Description": "A simple widget",
"ReleaseDate": "1991-01-01T00:00:00Z",
"DiscontinuedDate": null,
"Rating": 4,
"Price": 2.5
}
但是,当我这样做时,该服务实际上会使用我提交的 ID 并返回使用该主键的实体 URL,即使具有该键的实体已经存在。
然后当我尝试获取该 URL 时,响应只是说 Syntax Error
.当我查询整个集合时,我可以看到现在有两个实体 ID=0
,以前存在的那个和我创建的那个。
这只是引用服务实现中的一个错误吗?还是 OData 真的没有规定来处理在创建实体时让服务分配主键的(大概很常见的)场景?
最佳答案
这是服务实现中的错误。很可能 ODataDemo.Product
尚未在 ORM 或基础数据库中声明身份种子。
危险信号是,如果发布的结果是 ID 为零(或任何 ID),允许您创建具有相同 ID 的多行并且没有出现错误,则该数据类型没有正确定义。
在服务中按您预期的方式运行(代表您植入身份列),结果将是响应中的 ID 将是基础数据库表的下一个增量 ID,而不是您传入的 ID .
An implementation that allows multiple rows to have the same ID is not OData v4 compliant, unless of course the ID column IS NOT the primary key column. The syntax for selection or operating on a single record depends on the existence and declaration of the column that can be used to uniquely reference each row.
This is the column that is referenced by the value
11
in the brackets in the url:.../Products(11)
关于OData V4.0 : Auto-assign primary key when creating an entity,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48775820/
假设有一个创建用户的操作。如果存在指定的电子邮件或用户名,此操作可能会失败。如果它失败了,则需要确切地知道原因。在我看来,有三种方法可以做到这一点,我想知道是否有明显的赢家。 所以,这是一个类用户:
var obj1 = Object.create; console.log(typeof obj1); var obj2 = Object.create(null); console.log(type
I am getting this error after running npm run build yield User.create({^在运行NPM Run Build Year Use
我应该为其他人将从中继承的第一个父对象传递哪个参数,哪个参数更有效 Object.create(Object.prototype) Object.create(Object) Object.creat
我正在尝试使用 JDBC(最新版本)设置 SQL Server 2008 数据库。 我有一个我想一起执行的 setup sql 命令列表: 基本上我做的是: connection.setAutoCom
我正在尝试创建一个 CloudFormation 模板来创建一个 Auto Scaling 组,以便我可以从中启动 2 个实例。 我已经创建了 Auto Scaling 组,但我不知道如何编写用于从
我正在创建我的第一个WordPress网站。我已经在我的网站上安装了Elementor Pro插件。随之而来的一个有利因素是“循环旋转木马”。。。当我把它添加到我的页面时,一切似乎都在工作,但是当我点
create-react-app error 我从终端运行yarn start时收到此错误消息...我尝试了sudo killall node和许多其他过程来清除i-node却没有成功。 我也将我的c
在 CRM 中,当我尝试设置工作流程时,我可以选择与某个实体的创建时间相关的超时。涉及三个字段。 记录创建于 创建于 修改时间 虽然最后一个很明显,但我看不出其他两个之间有任何逻辑上的区别。 最佳答案
我在一次采访中被问到这个问题。我无法回答。 "browserslist": [ ">0.2%", "not dead", "not ie <= 11", "not op_mini all" ] 我可以
这是一个 Rails 新手问题: 当我在模型上调用 create() 时,它会绕过关联的 Controller create 操作吗? 例如,这没有命中我的标签 Controller #create
我不明白这两种特权之间的区别。 我找到了这两种解释,但对我没有帮助。 CREATE TABLE -> Enables a user to create a table owned by that us
我是 SharePoint 工作流的新手。 创建新任务并分配 TaskId 时,我有两个选项: 创建一个新字段来保存 TaskId 创建一个新属性来保存 TaskId。 新属性是一个依赖属性。 我的问
我突然注意到我们的代码库中有一个TDataModuleTestExchange(nil)“构造函数调用”: procedure TDialoogConfigExchange.ButtonTestCli
我有一个具有 TComponent 变量的单元,我在单元初始化时创建此组件,如下所示: var XComp: TComponent; . . . . initialization begin
Composer 是否提供了更新项目创建时使用的包的方法?即,如果我使用以下内容创建一个新的 Laravel 项目 composer create-project --prefer-dist lara
在 Hibernate 中,如果我们将 hbm2ddl.auto 设置为 create/create-drop ,那么它将在启动时删除旧模式并创建新模式。这意味着,它也会删除数据?..我的疑问是,如果
我使用了 create an Automated Build 中的此链接 ( this guide ) . 浏览器错误控制台显示: https://hub.docker.com/v2/reposito
我已经搜索了 msdn 并没有找到答案。我应该知道有什么区别吗? 如果真的没有区别,那么为什么会存在这种冗余? --SQL Server Stored Procedure Syntax CREATE
我有以下内容: var CardViewModel = function (data) { ko.mapping.fromJS(data, {}, this); this.editin
我是一名优秀的程序员,十分优秀!