Python的Django架構中的資料過濾功能

來源:互聯網
上載者:User
我們很少會一次性從資料庫中取出所有的資料;通常都只針對一部分資料進行操作。 在Django API中,我們可以使用`` filter()`` 方法對資料進行過濾:

>>> Publisher.objects.filter(name='Apress')[]

filter() 根據關鍵字參數來轉換成 WHERE SQL語句。 前面這個例子 相當於這樣:

SELECT id, name, address, city, state_province, country, websiteFROM books_publisherWHERE name = 'Apress';

你可以傳遞多個參數到 filter() 來縮小選取範圍:

>>> Publisher.objects.filter(country="U.S.A.", state_province="CA")[]

多個參數會被轉換成 AND SQL從句, 因此上面的代碼可以轉化成這樣:

SELECT id, name, address, city, state_province, country, websiteFROM books_publisherWHERE country = 'U.S.A.'AND state_province = 'CA';

注意,SQL預設的 = 操作符是精確匹配的, 其他類型的尋找也可以使用:

>>> Publisher.objects.filter(name__contains="press")[]

在 name 和 contains 之間有雙底線。和Python一樣,Django也使用雙底線來表明會進行一些魔術般的操作。這裡,contains部分會被Django翻譯成LIKE語句:

SELECT id, name, address, city, state_province, country, websiteFROM books_publisherWHERE name LIKE '%press%';

其他的一些尋找類型有:icontains(大小寫無關的LIKE),startswith和endswith, 還有range(SQLBETWEEN查詢)。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.