如何解决如何更改在 Swagger UI 中生成的 API 平台中的 SQL 查询
我们使用带有 Symfony 5 的 APi 平台为旧数据库创建 REST API。数据库中的表具有字段 created_at
,该字段设置为 CURRENT_TIMESTAMP
。因此,我们不在应用程序中管理它。
为了说明,假设一个表格如下所示:
- id
- 姓名
- 内容
- created_at
现在客户端会发送这样的 JSON:
{
"name": "Legacy database","contents": "This comes in"
}
当客户端使用 curl
或在其客户端应用程序中发出 POST 请求时,这可以正常工作。
但是,当他们通过 Swagger UI 检查 REST API 时,生成的 sql 查询如下所示:
INSERT INTO table (name,contents,created_at) VALUES ("Legacy database","This comes in",null)
这失败了,因为:
违反完整性约束:1048 列“created_at”不能为 空"
在实体中,属性 createdAt
看起来像这样,带有注释:
/**
* @var \DateTime
*
* @ORM\Column(name="created_at",type="datetime",nullable=true)
* @ORM\Version
*/
protected $createdAt;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。