1. 程式人生 > 實用技巧 >ORM 物件查詢,單表條件查詢,多表條件關聯查詢

ORM 物件查詢,單表條件查詢,多表條件關聯查詢

物件查詢、單表條件查詢、多表條件關聯查詢

1.ORM基於物件的正向查詢和反向查詢:

正向:物件呼叫屬性

反向:繫結的外來鍵的那個關係表的對面呼叫 “父級_set”

#--------------------物件形式的查詢--------------------------
    # 正向查詢
    ret1=models.Book.objects.first()
    print(ret1.title)
    print(ret1.price)
    print(ret1.publisher)
    print(ret1.publisher.name)  #因為一對多的關係所以ret1.publisher是一個物件,而不是一個queryset集合
# 反向查詢 ret2=models.Publish.objects.last() print(ret2.name) print(ret2.city) #如何拿到與它繫結的Book物件呢? print(ret2.book_set.all()) #ret2.book_set是一個queryset集合

2. django model filter比較引數

__gt     大於

__gte   大於等於

__lt      小於

__lte    小於等於

__in     存在於一個list範圍內

__startswith    以...開頭

__istartswith 以...開頭忽略大小寫 insensitivity不敏感 __endswith 以...結尾 __iendswith 以...結尾,忽略大小寫 __range 在...範圍內 __year 日期欄位的年份 __month 日期欄位的月份 __day 日期欄位的日 __isnull=True/False __overlap 集合至少有一個元素重合 __contains 集合包含 __regex 匹配正則表示式

3.多表條件關聯查詢

雙下劃線(__)之多表條件關聯查詢

# 正向查詢(條件)

#     ret3=models.Book.objects.filter(title='Python').values('id')
#     print(ret3)#[{'id': 1}]

      #正向查詢(條件)之一對多

      ret4=models.Book.objects.filter(title='Python').values('publisher__city')
      print(ret4)  #[{'publisher__city': '北京'}]

      #正向查詢(條件)之多對多
      ret5=models.Book.objects.filter(title='Python').values('author__name')
      print(ret5)
      ret6=models.Book.objects.filter(author__name="alex").values('title')
      print(ret6)

      #注意
      #正向查詢的publisher__city或者author__name中的publisher,author是book表中繫結的欄位
      #一對多和多對多在這裡用法沒區別

# 反向查詢(條件)

    #反向查詢之一對多:
    ret8=models.Publish.objects.filter(book__title='Python').values('name')
    print(ret8)#[{'name': '人大出版社'}]  注意,book__title中的book就是Publisher的關聯表名

    ret9=models.Publish.objects.filter(book__title='Python').values('book__authors')
    print(ret9)#[{'book__authors': 1}, {'book__authors': 2}]

    #反向查詢之多對多:
    ret10=models.Author.objects.filter(book__title='Python').values('name')
    print(ret10)#[{'name': 'alex'}, {'name': 'alvin'}]

    #注意
    #正向查詢的book__title中的book是表名Book
    #一對多和多對多在這裡用法沒區別

條件查詢即與物件查詢對應,是指在filter,values等方法中的通過__來明確查詢條件。