【发布时间】:2018-06-21 09:06:15
【问题描述】:
我在 Django 中设置了一个数据库模型来跟踪投资组合,并且正在尝试开发一个 API 来返回投资组合以及其中的每个硬币,以及与硬币相关的每笔交易。但是使用 api 我只看到我的模型的名称字段被返回。一些澄清代码:
模型.py:
class Portfolio(models.Model):
name = models.CharField(max_length=250)
@property
def coins(self):
return Coin.objects.filter(portfolio=self)
def transactions(self):
return Transaction.objects.filter(portfolio=self)
def __str__(self):
return self.name
class Coin(models.Model):
portfolio = models.ForeignKey(Portfolio, on_delete=models.PROTECT)
name = models.CharField(max_length=100)
symbol = models.CharField(max_length=5)
price = models.DecimalField(max_digits=20, decimal_places=9)
info = models.TextField()
website = models.TextField()
rank = models.IntegerField()
def __str__(self):
return self.name + " - " + self.symbol
class Transaction(models.Model):
portfolio = models.ForeignKey(Portfolio, on_delete=models.CASCADE)
coin = models.ForeignKey(Coin, on_delete=models.PROTECT)
purchaseDate = models.DateTimeField()
soldDate = models.DateTimeField(default=None, null=True, blank=True)
amount = models.DecimalField(max_digits=20, decimal_places=3)
price = models.DecimalField(max_digits=20, decimal_places=9)
def __str__(self):
return self.coin.name + " - " + str(self.amount) + " At $" + str(self.price)
我的 json 序列化器:
class PortfolioSerializer(serializers.ModelSerializer):
class Meta:
model = Portfolio
fields = '__all__'
数据如何返回:
HTTP 200 OK
Allow: GET, POST, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept
[
{
"id": 3,
"name": "Binance"
}
]
我想要的是在数据集中,在 binance 下它应该显示一个硬币对象列表,其中包含每个硬币的交易列表。
【问题讨论】:
-
由于
Coin中的外键关系,您不能删除属性硬币并直接调用portfolio.coins吗?这不是您问题解决方案的一部分,但您正在创建一个属性,而 Django 已经为您制作了这个属性。另外为什么交易突然不是财产?你应该检查一下。除了这样做之外,您还创建了两个根本不需要的额外查询!
标签: python json django django-rest-framework