Django admin 后台定制库存管理的中的入库管理

Django 的admin或xadmin定制后台管理十分方便,在此就不多说了,我今天想说的一个问题是,如何实现admin的不同表间不同字段的管理操作(描述不太清晰,不要在意)。(使用MySQL数据库)

我举个例子,如我做了个图书管理系统,涉及到库存的入库操作,但又不想在原有的库存上进行加减(原则上应该也不允许)。

(可能admin本身有解决方案,怪本人学艺不精,勿喷)

以下是我的解决方法:


首先列出我的图书表:

class Books(BaseModel):
    '''商品模型类'''
    books_type_choices = ((k, v) for k,v in BOOKS_TYPE.items())
    status_choices = ((k, v) for k,v in STATUS_CHOICE.items())
    type_id = models.SmallIntegerField(default=EDUCATION, choices=books_type_choices, verbose_name='种类')
    name = models.CharField(max_length=20, verbose_name='名称')
    desc = models.CharField(max_length=128, verbose_name='简介')
    price = models.DecimalField(max_digits=10, decimal_places=2, verbose_name='价格')
    unit = models.CharField(max_length=20, verbose_name='出版社')
    stock = models.IntegerField(default=1, verbose_name='库存')
    sales = models.IntegerField(default=0, verbose_name='销量')
    detail = HTMLField(verbose_name='详情')
    image = models.ImageField(upload_to='books', verbose_name='图片')
    status = models.SmallIntegerField(default=ONLINE, choices=status_choices, verbose_name='状态')

    objects = BooksManager()

    # admin显示书籍的名字
    def __str__(self):
        return self.name

    class Meta:
        db_table = 's_books'
        verbose_name = '书籍'
        verbose_name_plural = '书籍'

1.新定义定义一张表只用作入库操作,

class BookPurchase(BaseModel):
    book = models.ForeignKey('books.Books', verbose_name='订单商品')
    purchase = models.IntegerField(default=0, verbose_name='采购数量')
    
    def purchase_options(self):
        self.book += self.purchase
        
    class Meta:
        db_table = 's_books_purchase'
        verbose_name = '入库管理'
        verbose_name_plural = '入库管理'

2.在数据库对应操作表上插入触发器:

create trigger update_stock after insert 
on s_books_purchase
for each row
begin
update s_books set stock=stock+new.purchase where id=new.book_id;
end

这样就实现了配合admin的入库管理操作,(现实开发可能不可取)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值