1. 为什么要在INSTALLED_APPS中加入crispy_forms

    • 因为django-crispy-forms 是对django formhtml页面呈现方式进行管理的一个第三方插件。
  2. 为什么有时候定义model时,会将外键设置成指向自己?

    • 比如有这种需求,一个商品类目(GoodsCategory)的Model,它有一个字段是父级目录(parent_category),父级目录应该是一个外键并引用GoodsCategory, 即

      class GoodsCategory(models.Model):
      """
      some other filed
      """
      parent_category = models.ForeignKey(GoodsCategory)

      显然,这样会报错,因为定义parent_category的时候,GoodsCategory还没有定义,不过不用担心,django已经有了解决措施,只需要在定义时将ForeignKey所引用的Model改为‘self’即可,即

      class GoodsCategory(models.Model):
      """
      some other filed
      """
      parent_category = models.ForeignKey("self")

      这样在同步models至数据库时就会生成一个引用自己的外键

      本答案参考这篇文章Django Model的外键自关联‘self’和设置‘unique_together’

  3. python class嵌套怎么访问父类?

    • 例如:

      class parent:
      def __init__(self):
      self.name = 'parent' def getName(self):
      print(self.name) class child:
      def getName(self):
      #如何访问父类的name值 if __name__ == '__main__':
      child = parent.child()
      child.getName()
    • 答:由于parent.name在parent实例化之前不存在,所以child没办法访问到parent.name,有两种办法:

      ## 方法一:
      
      class parent:
      name = 'parent' def getName(self):
      print(self.name)
      class child:
      def getName(self):
      return parent.name if __name__ == "__main__":
      child = parent.child()
      child.getName() ## 方法二: class parent:
      def __init__(self):
      self.name = 'parent' def getName(self):
      print(self.name) class child:
      def __init__(self.parent):
      self.parent = parent def getName(self):
      return self.parent.name if __name_- == '__main__':
      parent = parent()
      child = parent.child(parent)
      child.getName()
  4. 为什么在创建model类时要嵌套一个meta类?

    • 第一个就是在商品类目里面设置了一个verbose_name=‘商品类别’,verbose_name_plural = verbose_name

      • 其实第一个等号的意思,就是给你的模型类起一个更可读的名字,在这里就是给GoodsCategory起一个名字叫 商品类别;
      • 第二个等号的意思是把 verbose_name指定为复数形式,如果不指定,则Django会自动在模型名称后面加上一个‘s’
      • 其实就是为了干预数据库建表名等操作,因为数据库中生成的表名称是 app名称 + 下划线 + 类名 ,有可能与数据库中的真正表名不一样,就会出现找不到表名的错误。

    注意:关于设置字段时的一些值的含义

    • IntegerFiled不需要设置最大长度的,否则会抛一个警告

    • help_text表示的是帮助文档

    • 外键约束中,on_delete = models.CASCADE,表示被外键约束的表,那么主表每个字段删除,相应受牵连的表的字段也会被删除

    • related_name = $$ 这个设置的是在一对多查询,进行反向查询时采用的语法结构,举个例子:

      我先定义两个模型,一个是作者,一个是作者出版的书籍,算是一对多的类型。
      
      class Person(models.Model):
      name = models.CharField(verbose_name='作者姓名',max_length=10)
      age = models.IntegerField(verbose_name='作者年龄') class Book(models.Model):
      person = models.ForeignKey(Person, related_name='person_book')
      title = models.CharField(verbose_name='书籍名称', max_length=10)
      pubtime = models.DateField(verbose_name='出版时间') ## 我们有一个需求,就是想查询一个作者出版了哪些书籍 #有两种方式可以实现
      '''
      方式一:
      先查询到作者的信息
      person = Person.objects.fiter(你的条件)
      返回一个person对象
      接下来就查询person关联的所有书籍对象,可以使用基于对象的查询方式,反向查询按照表名
      book = person.book_set.all()
      django 默认每个主表的对象都有一个是外键的属性,可以通过它来查询到所有属于主表的子表的信息。
      这个属性的名称默认是以子表的名称小写加上_set()来表示,默认返回的是一个querydict对象,你可以继续的根据情况来查询等操作。 方式二:
      上述可能比较麻烦
      可以在定义主表的外键的时候,给这个外键定义好一个名称。要用related_name比如在Book表中:
      person = models.ForeignKey(
      Person,related_name='person_books')
      那么实现上面的需求,可以使用person.book_set.all()
      也可以使用person.person_books.all()
      '''

等会整理:

[python-django 模型model字段类型说明]

models字段含义与用法

django模型内部类meta详解

生鲜超市项目错误及解决办法(crispy_forms、外键指向自己、class嵌套访问父类、meta类及各种字段参数)的更多相关文章

  1. 生鲜超市项目错误及解决办法(安装mysqlclient)

    错误1:安装Mysqlclient D:\Mxshop>pip install mysqlclient- 1.4.4-cp27-cp27m-win32 报错: ERROR: Could not ...

  2. VS2010出现FileTracker : error FTK1011编译错误的解决办法

    VS2010出现FileTracker : error FTK1011不知道是不是vs2010的一个bug,反正有人提交了. FileTracker : error FTK1011编译错误的解决办法有 ...

  3. java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法

    java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法 (2011-05-05 16:08:05) 转载▼ ...

  4. 【技术贴】解决myeclipse SVN 提交代码 commit:remains in tree-conflict错误的解决办法

    [技术贴]解决myeclipse SVN 提交代码 commit:remains in tree-conflict错误的解决办法 错误是:Aborting commit: xxxxx’ remains ...

  5. tensorflow_mnist数据集一直加载错误的解决办法

    tensorflow数据集一直加载错误的解决办法: from tensorflow.examples.tutorials.mnist import input_data mnist = input_d ...

  6. 小账本APP——软件项目风险管理及解决办法案例

    小账本APP——软件项目风险管理及解决办法案例 摘要 软件项目风险是指在软件开发过程中遇到的预算和进度等方面的问题以及这些问题对软件项目的影响.软件项目风险会影响项目计划的实现,如果项目风险变成现实, ...

  7. github常见操作和常见错误及其解决办法

    一.常见操作 1. 使用git在本地创建一个项目的过程 $ makdir ~/hello-world //创建一个项目hello-world $ cd ~/hello-world //打开这个项目 $ ...

  8. Eclipse 报 "The builder launch configuration could not be found" 错误的解决办法

    http://blog.csdn.net/defonds/article/details/26340561 Eclipse 忽然报 "The builder launch configura ...

  9. 问题:Custom tool error: Failed to generate code for the service reference 'AppVot;结果:添加Service Reference, 无法为服务生成代码错误的解决办法

    添加Service Reference, 无法为服务生成代码错误的解决办法 我的解决方案是Silverlight+WCF的应用,Done Cretiria定义了需要在做完Service端的代码后首先运 ...

随机推荐

  1. echarts使用------地图生成----省市地图的生成及其他相关细节调整

    为使用多种业务场景,百度echarts地图示例只有中国地图,那么在使用省市地图的时候,就需要我们使用省市的地图数据了 以下为陕西西安市的地图示例: 此页面引用echarts的js:http://ech ...

  2. 树莓派4b+linux

    用Win32DiskImager烧录系统 先在boot根目录下新建ssh空文件夹来开启ssh功能,否则ssh是关闭的,用putty一直连不上,显示拒绝连接 1.联网: 初次 (实践证明:直接在sd卡根 ...

  3. Vue中MVVM模式的双向绑定原理 和 代码的实现

      今天带大家简单的实现MVVM模式,Object.defineProperty代理(proxy)数据   MVVM的实现方式: 模板编译(Compile) 数据劫持(Observer) Object ...

  4. Loj #2719. 「NOI2018」冒泡排序

    Loj #2719. 「NOI2018」冒泡排序 题目描述 最近,小 S 对冒泡排序产生了浓厚的兴趣.为了问题简单,小 S 只研究对 *\(1\) 到 \(n\) 的排列*的冒泡排序. 下面是对冒泡排 ...

  5. 快速认识springcloud微服务

    这周浅显的学习了springcloud.简单聊一下微服务.所谓的微服务远远没有我想想的那么高端难以理解,简单说,就是多个服务分布在不同的服务器上,由这些服务互相配合完成某一项任务.那服务和服务之间调用 ...

  6. Python字典(Dictionary)update()方法

    原文连接:https://www.runoob.com/python/att-dictionary-update.html Python字典(dictionary)update()函数把字典dict2 ...

  7. Tensorflow faster rcnn系列一

    注意:本文主要是学习用,发现了一个在faster rcnn训练流程写的比较详细的博客. 大部分内容来自以下博客连接:https://blog.csdn.net/weixin_37203756/arti ...

  8. kali渗透综合靶机(七)--Super-Mario-Host靶机

    kali渗透综合靶机(七)--Super-Mario-Host靶机 靶机百度云下载  链接:https://pan.baidu.com/s/13l1FUgJjXArfoTOfcmPsbA 提取码:a8 ...

  9. IIS 503错误解决办法 HTTP Error 503

    今天在win7上部署一个IIS网站,莫名出现HTTP Error 503,于是对比了一下之前的网站配置,依然无果. 无奈之下,挨个查看IIS配置.查看“事件查看器”,尝试修改应用程序池 - 高级设置 ...

  10. Mysql 报错:#1067 - Invalid default value for 'update_time

    由于 字段UPDATE_TIME 的字段类型是 timestamp ,默认值是:'0000-00-00 00:00:00' 即:`UPDATE_TIME` timestamp NOT NULL DEF ...