django xadmin 错误:related Field has invalid lookup: icontains

错误提示:related Field has invalid lookup: icontains 

 问题:设置查询某表的字段为‘外键字段名’

分析:设置某表的查询字段应该是相关联的明确一个字段,而不是一张表

解决方法:将查询字段设为 '外键字段名__关联表的具体字段名'

具体实例如下:

models.py

from django.db import models

class Medicines(models.Model):
    id = models.IntegerField(primary_key=True,verbose_name='药品编号')
    name = models.CharField(max_length=50, null=False, verbose_name='药品名称')
    mode = models.CharField(max_length=20,null=True, verbose_name='药品类型')
    efficacy = models.CharField(max_length=100, null=True, verbose_name='药品功效')
    
    class Meta:
        db_table = 'tb_medicines'
        verbose_name = '药品信息'
        verbose_name_plural = verbose_name
    def __str__(self):
        
        return '%s' %( self.name)

    
class SKU(models.Model):
    medicine = models.ForeignKey(Medicines, on_delete=models.CASCADE, verbose_name='商品')
    price = models.DecimalField(max_digits=10, decimal_places=2, verbose_name='单价')
    cost_price = models.DecimalField(max_digits=10, decimal_places=2, verbose_name='进价')
    market_price = models.DecimalField(max_digits=10, decimal_places=2, verbose_name='市场价')
    stock = models.IntegerField(default=0, verbose_name='库存')
    sales = models.IntegerField(default=0, verbose_name='销量')
    date = models.DateField(auto_now=True, verbose_name='日期')


    class Meta:
        db_table = 'tb_sku'
        verbose_name = '药品库存'
        verbose_name_plural = verbose_name

    def __str__(self):
        # return '%d-%d-%d-%d-%d-%d' % (self.id, self.price, self.cost_price, self.market_price, self.stock, self.sales)
        return '%s' % (self.medicine.name)

adminx.py

import xadmin
from medicines import models

class SKUAdmin(object):
    model_icon = 'fa fa-gift'
    list_display = ['medicine', 'price', 'cost_price', 'market_price', 'stock', 'sales','date']
      # 指定要搜索的字段
    list_filter = ['medicine','date']  # 指定过滤字段
    list_export = ['xls']
    refresh_times = [3, 5]  # 可选以支持按多长时间(秒)刷新页面
    data_charts = {
        "medicine_sales": {'title': '药品销量', "x-field": "date", "y-field": ('sales',),
                           "order": ('date',)},
        "medicine_market_price": {'title': '市场价', "x-field": "date", "y-field": ('market_price',),
                        "order": ('date',)},
        "medicine_price": {'title': '单价', "x-field": "date", "y-field": ('price',),
                        "order": ('date',)},
        "medicine_cost_price": {'title': '进价', "x-field": "date", "y-field": ('cost_price',),
                                  "order": ('date',)},
    }


xadmin.site.register(models.SKU, SKUAdmin)

 其中SKU表的medicine为外键字段关联Medicines表

SKU表想要根据关联表Medicines的name字段查询

正确设置为‘search_fields = ['medicine__name']’,即‘关联表字段名__关联表查询字段’

 

问题解决,大功告成

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值