【问题标题】:Do I have to use Django Models to use the API?我是否必须使用 Django 模型才能使用 API?
【发布时间】:2021-06-26 10:51:58
【问题描述】:

我们正在迁移我们的 Intranet 应用程序并决定选择 Django 框架。我们通过源代码控制和托管脚本控制所有数据库,因此我们不使用migrate 功能为我们创建表。视图和表可以更改,所有业务逻辑都保存在数据库中。

我想制作 Django API 端点,它基本上是 select * from my_table_or_view;,并且 Django 可以返回带有列名和值的 JSON 响应。一些数据库表每个都有接近 100 列,所以我不想写出每个字段名称并键入只是为了返回查询。如果我们在视图中添加另一列会发生什么——我是否也必须在 Django 中更新它?如果我更改列类型怎么办 - 我的应用程序也会失败吗?

前端是用 VueJS 编写的——它向 API 端点发出请求,并且应该使用在前端选择的列,显然如果我删除一个列,它会中断,但我不想在其中添加列django 框架,即使它没有被使用。

我已阅读文档的the raw SQL queries 部分,但我不确定这适用于何处。此逻辑是否位于视图部分?

我尝试将 URLS.py 中的 URL 端点指向 views.py 中的自定义类,但不确定这是否正确,此逻辑是否需要在序列化程序中?

我想要最简单的方法,可能不使用模型,只使用原始 SQL 就可以了。

【问题讨论】:

  • 那是非常多的问题、叙述和不必要的背景。陈述这个问题的最小方法是什么?您是否只想从表中选择 * 并从端点返回它?如果您只想在数据库上使用 API,则可以使用 github.com/PostgREST/postgrest 之类的东西,但从您的问题来看,您可能在 mysql 上。

标签: django django-models django-rest-framework


【解决方案1】:

您的一个选择是每次更改架构时将您的数据库同步到 django 模型,然后正常使用它,ORM 和原始 SQL 查询都是可能的。

有一个名为 inspectdb 的函数可以在本地执行此操作,这是对它的引用 https://docs.djangoproject.com/en/3.1/ref/django-admin/#inspectdb

【讨论】:

  • 我知道 inspectdb 函数,但我仍然不希望在我的 django 模型代码中包含数千行列定义 - 我是否真的需要声明模型?我可以只写原始 SQL 吗?
  • 您可以使用直接连接库:stackoverflow.com/questions/5931586/…
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-03-05
  • 1970-01-01
  • 1970-01-01
  • 2014-09-11
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多