models.py 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. from hashlib import sha1
  2. from django.db import models
  3. from django.db.models import PROTECT
  4. proto = sha1()
  5. class User(models.Model):
  6. no = models.AutoField(primary_key=True, db_column='uno', verbose_name='编号')
  7. username = models.CharField(max_length=20, unique=True, verbose_name='用户名')
  8. password = models.CharField(max_length=40, verbose_name='口令')
  9. email = models.CharField(max_length=255, verbose_name='邮箱')
  10. counter = models.IntegerField(default=3, verbose_name='票数')
  11. def save(self, force_insert=False, force_update=False, using=None, update_fields=None):
  12. hasher = proto.copy()
  13. hasher.update(self.password.encode('utf-8'))
  14. self.password = hasher.hexdigest()
  15. super().save(force_insert, force_update, using, update_fields)
  16. class Meta(object):
  17. db_table = 'tb_user'
  18. verbose_name = '用户'
  19. verbose_name_plural = '用户'
  20. class Subject(models.Model):
  21. no = models.AutoField(primary_key=True, db_column='sno', verbose_name='编号')
  22. name = models.CharField(max_length=50, db_column='sname', verbose_name='学科名称')
  23. intro = models.CharField(max_length=511, db_column='sintro', verbose_name='学科介绍')
  24. def __str__(self):
  25. return self.name
  26. class Meta(object):
  27. db_table = 'tb_subject'
  28. verbose_name = '学科'
  29. verbose_name_plural = '学科'
  30. class Teacher(models.Model):
  31. no = models.AutoField(primary_key=True, db_column='tno', verbose_name='编号')
  32. name = models.CharField(max_length=20, db_column='tname', verbose_name='姓名')
  33. intro = models.CharField(max_length=1023, db_column='tintro', verbose_name='简介')
  34. motto = models.CharField(max_length=255, db_column='tmotto', verbose_name='教学理念')
  35. photo = models.CharField(max_length=511, db_column='tphoto', verbose_name='照片', null=True, blank=True)
  36. subject = models.ForeignKey(Subject, db_column='sno', on_delete=PROTECT, related_name='+', verbose_name='所属学科')
  37. manager = models.BooleanField(default=False, db_column='tmanager', verbose_name='是否主管')
  38. good_count = models.IntegerField(default=0, db_column='tgcount', verbose_name='好评数')
  39. bad_count = models.IntegerField(default=0, db_column='tbcount', verbose_name='差评数')
  40. @property
  41. def gcount(self):
  42. return f'{self.good_count}' \
  43. if self.good_count <= 999 else '999+'
  44. @property
  45. def bcount(self):
  46. return f'{self.bad_count}' \
  47. if self.bad_count <= 999 else '999+'
  48. class Meta(object):
  49. db_table = 'tb_teacher'
  50. verbose_name = '讲师'
  51. verbose_name_plural = '讲师'
  52. ordering = ('no', )