1. Aprende
  2. /
  3. Cursos
  4. /
  5. Pythonで学ぶデータベース入門

Connected

Ejercicio

テーブルから選択したデータのフィルタリング - 応用

かなり慣れてきましたね!SQLAlchemy では、より複雑なフィルタリングを行うために and_(), or_(), not_() といった連結(論理演算)も使えます。たとえば、次のコードで、ニューヨーク州に住み、年齢が 21 歳または 37 歳の人のレコードを取得できます。

select([census]).where(
  and_(census.columns.state == 'New York',
       or_(census.columns.age == 21,
          census.columns.age == 37
         )
      )
  )

同等の SQL は次のようになります。

SELECT * FROM census WHERE state = 'New York' AND (age = 21 OR age = 37)

Instrucciones

100 XP
  • sqlalchemy モジュールから and_ をインポートします。
  • census テーブルのすべてのレコードを選択します。
  • where 句を追加し、state が 'California' で、かつ sex が 'M' ではないレコードをすべてフィルタリングします。
  • 接続で stmt を実行し、ResultProxy を反復処理して、各レコードの age 列と sex 列を出力します。