2014年7月22日火曜日

開発環境

Head First SQL ―頭とからだで覚えるSQLの基本 (Lynn Beighley(著)、 佐藤 直生 (監訳)、 松永 多苗子 (翻訳)、オライリージャパン)の2章(SELECT 文: 天賦のデータ検索)、エクササイズ(p.81)を解いてみる。

エクササイズ(p.81)

コード(BBEdit, Emacs)

sample81.py

#!/usr/bin/env python3
#-*- coding: utf-8 -*-

import sqlite3

connection = sqlite3.connect('gregs_list.sqlite')
cursor = connection.cursor()

def p(msg):
    print(msg)
    for row in cursor.fetchall():
        print(row)

cursor.execute("""SELECT * FROM my_contacts""")
print(tuple(map(lambda header: header[0], cursor.description)))
p("全て")

cursor.execute("""
SELECT email FROM my_contacts
WHERE profession = 'コンピュータプログラマ'
""")
p('全てのコンピュータプログラマのメールアドレス')

cursor.execute("""
SELECT first_name, last_name, location FROM my_contacts
WHERE birthday = '1970-04-01'
""")
p('名前と住所')

cursor.execute("""
SELECT first_name, last_name, email FROM my_contacts
WHERE location = 'ニュージャージー州グローバーズミル (Grover''s Mill)' AND
status = '独身'
AND
gender = 'M'
""")
p('名前、メールアドレス')

cursor.execute("""
SELECT first_name, last_name FROM my_contacts
WHERE location = 'カリフォルニア州サンフランシスコ' AND
first_name = 'アン'
""")
p('名前')

connection.close()

入出力結果(Terminal, IPython)

$ ./sample81.py
('last_name', 'first_name', 'email', 'gender', 'birthday', 'profession', 'location', 'status', 'interests', 'seeking')
全て
('スティーブ', 'ファンヨン', 'steve@onionflavoredrings.com', 'M', '1970-04-01', 'パンクミュージシャン', "ニュージャージー州グローバーズミル (Grover's Mill)", '独身', '国家の破壊', '同国人、ギタープレイヤー')
('スティーブ', 'ファンヨン', 'steve@onionflavoredrings.com', 'M', '1970-04-01', 'パンクミュージシャン', "ニュージャージー州グローバーズミル (Grover's Mill)", '独身', '国家の破壊', '同国人、ギタープレイヤー')
全てのコンピュータプログラマのメールアドレス
名前と住所
('ファンヨン', 'スティーブ', "ニュージャージー州グローバーズミル (Grover's Mill)")
('ファンヨン', 'スティーブ', "ニュージャージー州グローバーズミル (Grover's Mill)")
名前、メールアドレス
('ファンヨン', 'スティーブ', 'steve@onionflavoredrings.com')
('ファンヨン', 'スティーブ', 'steve@onionflavoredrings.com')
名前
$

0 コメント:

コメントを投稿