django model的get和filter方法的區別

django的get和filter方法是django model經常使用到的,搞清楚二者的區別很是重要。
  
  爲了說明它們二者的區別定義2個models
  
  class Student(models.Model):
      name = models.CharField('姓名', max_length=20, default='')
      age = models.CharField('年齡', max_length=20, default='')
  
  
  class Book(models.Model):
            student = models.ForeignKey(Student)
            
            
  一.先說下django的get方法:
  
  1django的get方法是從數據庫的取得一個匹配的結果,返回一個對象,若是記錄不存在的話,它會報錯。
  好比我數據庫裏有一條記錄,記錄的name的值是"Python"的話,我用student = Student.objects.get(name='老王python'),
  返回的是一個記錄對象,你能夠經過student.__dict__來查看,它返回的是一個字典的形式,{'key':valeus},key是字段的名稱,而values是值的內容。
  而若是我用get方法來查詢一個數據庫裏不存在的記錄,程序會報錯。
  好比:student = Student.objects.get(name='老王'),你本身能夠運行看下。
  
  2若是你用django的get去取得關聯表的數據的話,而關鍵表的數據若是多於2條的話也會報錯。
  好比個人student表裏有一個記錄:
  id   name     age
   1   python  24
   
   book表:
   
   id  student_id
    1      1
    2      1
   
   我用
   student = Student.objects.get(name='python')
   book = Book.objects.get(student)
   它也會報錯,由於book表有2條記錄和student表相匹配。
   
   
    二.再說下django filter:       1django的filter方法是從數據庫的取得匹配的結果,返回一個對象列表,若是記錄不存在的話,它會返回[]。    好比我數據庫裏有一條記錄,記錄的name的值是Python的話,我用student = Student.objects.filter(name='老王python')    它返回的student是一個對象的列表,能夠看的出來student[0]和上面的get方式返回的student的結果是同樣的。        2若是你用django的get去取得關聯表的數據的話,不管關聯表有多少記錄的都不會報錯。    django 除了model比較強大的話,表單和模板也很強大,想要了解表單的能夠看看:    另外我從別的資料裏看到filter好像有緩存數據的功能,第一次查詢數據庫並生成緩存,下次再調用filter方法的話,直接取得緩存的數據,會get方法每次執行都是直接查詢數據庫的,不知道這個是否是正確。
相關文章
相關標籤/搜索