0

我的models.py中有这个经理

class ItemManager(models.Manager):
 def get_fee(self):
 from django.db import connection
    cursor = connection.cursor()
    cursor.execute("""
        SELECT fee
        FROM item
        WHERE itemID = %d AND item.type = %d 
        """, [self.myItemID, self.myItemType])
    fee = cursor.fetchone()
    return fee

和班级

Sample(models.Model):
sampleID = models.AutoField(primary_key=True)
itemID = models.ForeignKey(Item)
item.type  = models.ForeignKey(Item)
    ...

def save(self, *args, **kwargs):
    is_new = self.pk is None
    super(Sample, self).save(*args, **kwargs)
    if is_new:
        cd.amount = MonthlyFeeManager() 
        cd.save()

然后它会产生一个错误:

Cannot convert <myapp.models.ItemManager object at 0xa6f07ec> to Decimal

一般来说,我想在管理器中执行 RAW SQL 查询并使用它从查询中获取结果。我试图搜索,但大多数返回是元组,而不是一个值。

4

1 回答 1

1

这不是你使用经理的方式。即使有一个完全正常的类实例,您的尝试也不会给您想要的东西:您需要实例化它并调用get_fee()实例。

使用管理器,您不需要实例化它,因为这已经作为objects模型上的属性为您完成了。但是你仍然需要调用相关的方法:

cd.amount = Sample.objects.get_fee()

但是,这仍然行不通。那是因为您引用了self.myItemIdand self.myItemType,它在 Manager 对象中不存在。这使我得出结论,您根本不需要 Manager 对象:您只需要标准模型方法。而且也不需要原始 SQL:您的代码可以使用正常的模型查询语法完全轻松地表达。

(我无法准确地向您展示它的外观,因为您示例中的 ForeignKeys 没有任何意义,并且不清楚fee应该从哪里来。)

于 2012-09-30T16:05:59.320 回答